数论:不定方程整数解
欧几里得算法
又称辗转相除法,迭代求两数 gcd。
由 $(a, b) = (a, ka + b)$ 的性质,$\gcd(a, b) = \gcd(b, a\bmod b)$。容易证明这么做的复杂度是 $O(\log n)$。
注意:$\gcd(0, a) = a$。
又称辗转相除法,迭代求两数 gcd。
由 $(a, b) = (a, ka + b)$ 的性质,$\gcd(a, b) = \gcd(b, a\bmod b)$。容易证明这么做的复杂度是 $O(\log n)$。
注意:$\gcd(0, a) = a$。
预处理向上跳 $2^k$ 步的结果数组 f[k][x]
。
求的时候先把两个点跳到一个深度。这里有一个特判,如果重合直接返回这个点。
然后log值从大往小枚举,两个点一起不断向上跳,直至父亲相同,直接返回父节点。
可以 $O(n)$ 预处理log值,把单次查询复杂度降到 $O(常数)$。
复杂度:预处理 $O(n \log n)$,查询 $O(1)$
他和她走下车。站台上熙熙攘攘的人守望在那里。没有人向他们看上一眼。
他们停下脚步,看着列车消失在金色的反光里,只留下无底的空白。
“所以……新见和五反田他们呢?”高桥问道。
“他们?他们不会来了。”他想了想道。“他们来过这里。”
她点了点头。
“走吧。”
他握住她的手。
健身房的年轻后生不讲武德偷袭马老师,把马保国老师的眼睛给蹭了一下
啊朋友们好啊,我是浑元形意太极门掌门人马保国。
刚才有个朋友,问我马老师发生甚么事了,我说怎么回事,给我发了几张截图。我一看,嗷,原来是左天,有两个年轻人,30多岁,一个体重90多公斤,一个体重80多公斤。塔们说,诶,有一个说是,我在健身房练功,颈椎练坏了,马老师你能不能教教我浑元功法,矮…帮助治疗一下我的颈椎病。我说可以。
时间戳:搜索时第几个搜索到这个点。如搜索顺序是1->2->3->6,则6的时间戳为4
连通分量:对于图G来的一个子图中,任意两个点都可以彼此到达,这个子图就被称为图G的连通分量(一个点就是最小的连通分量)
最大连通分量:对于图G的一个子图,这个子图为图G的连通分量,且是图G所有连通分量中包含节点数最多的那个,即为G的最大联通分量
1 |
|
1 |
|
$$
F(i,j)=
\begin{cases}
F(i-1,j)& j \leq w_i\\
\max{F(i-1,j),F(i-1,j-w_i)+v_i}& j > w_i
\end{cases}
$$
注意二维转换成一维的时候,$j$ 要从后向前枚举,因为每次的新结果都是根据上一个结果来求得的,从后向前可避免重复取同一物品。
货币使用问题:
尽可能少用,那么我们就先拿面值最大的,依次往下走,最后拿光了即可。
区间调度问题:
工作时间不能重叠,在可选工作中,每次都选取结束时间最早的作为选择,可以使工作量最大。
搜索和DP不分家,几乎所有的DP都能用搜索解决(虽然复杂度可能较劣)。不过,如果实在想不出正解,DFS不失为骗分的好手段。
主要的搜索算法有:
重要程度:1,7,6 > 4,3 > 5,2。
1 |
|
1 |
|
1 |
|
树形DP三大问题:树的最大独立集 树的重心 树的最长路径
以下步骤在 Butterfly主题上可以正常生效。如果你使用的是其他主题,可以根据情况自行适配。
hexo-tag-aplayer
的兼容问题如果你没有安装过 hexo-tag-aplayer
插件,请直接跳过该步骤。
如果你安装过 hexo-tag-aplayer
,请在 Hexo 的配置文件中修改以下设置: