Codeforces Round #218 (Div. 2)不完全不正确题解

A. K-Periodic Array

将Array切片,然后按位统计某一位上1的个数C(1)和2的个数C(2)。然后在这一位上的操作数就为M = min(C(1), C(2))。

简单题

B. Fox Dividing Cheese

傻逼才错的题,不幸中枪。

不想多说了,直接看代码吧。手贱不是病,贱起来要人命。

C. Hamburgers

模拟 + 二分。

和CJL还讨论过这题的纯模拟做法,看了半天代码没找到问题。于是刚才用Python自己实现了一个,在代码正确的情况下,没有WA,但是T在了22组上。

所以这题最好使用二分,如果用模拟的话,需要考虑各种情况。代码见下,细节上注意就好。

D. Vessels

这题得好好讲一下~比赛时做出来了好得意~

Vessels

题意是给出一组层层叠的容器,每一个容器都有自己的容量。然后我们向某些容器里灌水,如果水的体积超过了某个容器的容量,则剩余的水溢出到下一个容器中。最后一个容器溢出的水会落到地面上 …

more ...

使用新类型创建更人性化的代码

啥?

这篇文章讨论了如何通过新建并非”必要“的新类型,来产生更人性化的C++代码。

关键词:

  • RAII
  • 智能指针
  • 接口友好
  • 模板
  • 模板特化
  • 依赖编译器的缺省行为

对于C++的艺术,我只是个入门者。如果文章中有什么问题,欢迎大家指出,我会及时进行修改。

一个友好的互斥锁

互斥锁的定义

互斥锁(英语:英语:Mutual exclusion,缩写 Mutex)是一种用于多线程编程中,防止两条线程同时对同一公共资源(比如全局变量)进行读写的机制。该目的通过将代码切片成一个一个的临界区域(critical section)达成。临界区域指的是一块对公共资源进行访问的代码,并非一种机制或是算法。一个程序、进程、线程可以拥有多个临界区域,但是并不一定会应用互斥锁。

如何使用互斥锁

这里只做最简单的示范。具体的使用方法和原理不在本文的讨论范围之内。

#include <pthread.h>

class MyIntArray …
more ...

Yunfile下载破解[废弃]

废弃原因

因为Yunfile现在开始限IP + 无限抽风,所以插件已经废弃不用了。现在也没找到解决方法。\o<(=╯□╰=)>o

啥?

大家都知道Yunfile是做什么的咩?反正我是不知道。。。

今天下午无聊,写了一个yunfile下载的破解插件。

功能:

  • 非会员跳过下载等待的30s(或者更长时间)

  • 下载页面不会报“因长时间未操作,需要重新下载”的错误

这里感谢luacloud博文,为插件的编写提供了原型。

具体功能实现:

跳过等待

在上面引用的博文里面有说,就是强制执行页面中的js,实现跳转。

还做了一个DOM修改,变成现在这种很漂漂的样子~~

Yunfile-Craker-1

忽略超时错误

覆盖了下载函数,跳过超时判断。

现有问题

在一些情况下,点击下载按钮会返回到下载页。

虽然我们不需要再等30s了,但是还是很烦。

也有我有机会修复这个问题。

代码

代码在这里呀~

more ...


機器學習基石 - PLA算法初步

什么是PLA算法

PLA = Perceptrons Learning Alogrithm

WikiPedia上有一个大概的历史背景介绍。

感知机(英语:Perceptron)是Frank Rosenblatt在1957年就职于Cornell航空实验室(Cornell Aeronautical Laboratory)时所发明的一种人工神经网络。它可以被视为一种最简单形式的前馈式人工神经网络,是一种二元线性分类器。

PLA算法的原理

感知机示意图

对于每种输入值(1 - D),我们计算一个权重。当前神经元的总激发值(a)就等于每种输入值(x)乘以权重(w)之和。

由此我们就可以推导出公式如下。

neuron sum

我们可以为这个“神经元”的激发值设定一个阈值threshold

如果 a > threshold,则判定输入为正例。 如果 a < threshold,则判定输入为负例。 对于 a == threshold的情况,认为是特殊情况,不予考虑。

所以,我们的感知器分类器就可以得到以下式子 …

more ...

Linux内核中的少锁链表

前言

最近在stackexchange上看到一个问答,讨论我们常用的数据结构与算法在实际工程中的应用。(戳我)

我打算借助这个问答中的内容,以我比较熟悉的数据结构与算法为索引来阅读开源代码。

正文

Talk is cheap

Lock-less NULL terminated single linked list

linux-2.6/include/linux/llist.h

linux-2.6/lib/llist.c

知识准备

volatile

volatile关键字声明的变量或对象通常拥有和优化和(或)多线程相关的特殊属性。

通常,volatile关键字用来阻止(伪)编译器对那些它认为变量的值不能“被代码本身”改变的代码上执行任何优化。

如果不使用volatile关键字,编译器将假设当前程序是系统中唯一能改变这个值部分。 为了阻止编译器像上面那样优化代码,需要使用volatile关键字。

From: http://zh.wikipedia.org/wiki/Volatile%E5 …

more ...