records on

Records on
妄图使用数学方法解决组合问题的的人类,
悔改吧,组合意义蕴含的能量远超你想象

实际上,如同 title 所说的,从现在开始,将要开始记录。

也正如那些古老的石碑,存在的意义不是证明,而只是记录
属于我的故事开始了。
img

2022-3-24

T1

发现了,如果是合法解的话,那么一定可以拆分成下图这样的。

img2

后面的可以随便×个 \(2^k\)

前面要求那个不到 \(0\) 的子序列 \(B\) 要大于后面最大的。

其实后面的我们可以直接看成 \(B\) 把后面的全连起来了。

然后首先考虑怎么求,能划分成两个下降子序列的排列的个数。

往后面加数真的不是很容易,那么不妨考虑按值域枚举,一个一个插入。这个很关键。

这样,你考虑一下最后一个数能插到的地方,显然是一个连续段,所以不妨设dp状态。

\(f_{i,j}\) 表示插入了 \(i\) 个,产生的最后连续段长度是 \(j\)。你会发现我们如果向最后插入,我们钦定了第一个子序列必须选。

所以转移 \(f_{i,j}=\sum f_{i-1,k},k\geq j-1\)

所以化成后缀和,就变成了组合数(卡特兰),就完事了。

2022-3-24 这个codeforces 感觉挺可惜的,但实际上我觉得主要还是自己没有特别熟悉cf,找一找手感,估计会好起来的。

训练量太少了。

怎么就突然 2022-3-27了。。。。。

2022-3-25 的 T3

题目大意:一个树有两种颜色,每次修改操作为:一个颜色连通块+w,翻转一个点的颜色,链,子树+w,以及询问x所在连通块max。

和我最开始的预期差不多,链和子树可以轻易的使用重链剖分解决。

那么思考一下如何颜色相同连通块+,求max。

我们可以发现,对于一个树连通块,一定有一个顶点,那么所有修改的点都是这个点子树内的。

当然除了一些异色点分开了一些子树的话。

现在我们需要思考如何刻画在同一个联通块内的。

可以发现就是这个点到根异色点个数,就能很好描述这件事。

实际上,我们需要在x的子树内,将num等于num[x]的点全部修改。

这样我们本质上 [sz[x],sz[x]+dfn[x]-1] 上内的num[x]=num[v]的v进行修改。

这是不好改的,但是你发现 num[x]=num[v] 本质上也就是 num[x]=min。

这样是可以做的,但是注意我们一九需要 修改num[x] 所以我们pushdown的时候改变一下策略,先把 num 的tag pushdown这样可以保证现在p的num,和son[p] 的num是绝对正确的。

反过来想如果这个有tag的话,那么说明这个区间自从打tag开始就没有被修改了。

这么做的正确性便有了保障。

和xsy上一道题很像。。。。


约数的根号和?

这个大概就可以分析,因为sqrt积性,显然。。。 \[ \begin{aligned} \prod_i\sum_{j\leq a_i}(\sqrt {p^j})<\prod_{i}\frac{\sqrt{p^{a_i+1}}}{\sqrt{p}-1}=\sqrt n\prod \frac{\sqrt{p}}{\sqrt p-1}\\ \end{aligned} \] 后面那个不是很会分析/kk,按照邓老师说的可能是(?)\(\mathrm{polylog}\) 级别的?


迷失游乐园

挺水的,大概树和基环树唯一差别,只是多了一条可能有贡献的边。

我们就枚举这个边的贡献,完事了,simple 换根dp......其实挺复杂的。

2022-4-5

T3 很简单 f就是卡特兰,然后问你让 \(\binom{2n}{n}\)\(7\) 因子最大化。

我们都知道 \(\binom{n}{m}\)\(p\) 因子个数是 \(n+(n-m)\) \(p\) 进制下的进位数,所以换言之,我们要找到 \(l\leq x\leq r\) 使得 \(2x\) 进位数最多。

你可以贪心找到 \(l,r\) 的lcp后一位,接下来有两种选择。

  1. xxxxxxx (\(l_k-1\)) 666666666666666666666 这样的
  2. xxxxxxx(\(l_k\))3333333333333333333333334这样的

我们考虑 1 是普遍都有的。

2需要我们在找到前缀3,看下一位是否>=4。

比较卡我的地方是 高精度换进制。。。。。

复杂度 \(O(n^2/12)\) 当然是12个压一位,然后mod 7 直接加起来%7即可了。

T2 是原题。

大概就是先写出dp:(\(f_{i,j}\) 表示当你在i节点t时刻的最小期望长度) \[ f_{i,j}=\min{(f_{0,0}+j,\sum_{y,l\leq s\leq r}f_{y,j+s}\times p)} \] 含义是当前状态你可以选择会到初始情况。也可以继续走下去。

不能dp的主要原因是 \(f_{0,0}\) 很讨厌

然后这种题的思路就是你把 \(f_{0,0}\) 看成类似主元的东东。然后你分析一下你的 如果你设 \(x=f_{0,0}\),那么把转移的 \(f_{0,0}\)改成 \(x\) 后的,\(f_{0,0}\) 实际上是一个一次函数,实际上如果你考虑 所有 \(\min\) 的情况,他其实是一个直线取 min 也就是下凸壳。

我们实际上也是想解方程 \(F(x)=x\) 这种的。你考虑实际含义只能有一个解,那么直线与凸壳交点也只能有一个了,可以二分。

T1

。。。。我竟然忘记了点分治。

重写一下点分治用途,点分治可以将经过一个点的链,分成 \(\log\) 级别种。所以在处理链问题,点分治有奇效。。。


2022-4-26?

待修改的整体二分?我们那就得按照时间来自然定序了,考虑的时候并不是cdq,当前我们找到了答案 \([l,r]\) ,而操作时间区间为 \([ql,qr]\),那么对于一个 \(i\) 询问,我们只考虑前面当前合法的 (\([v_j\leq mid]\)) 的算上贡献,如果此时贡献足够了说明进到左递归区间,那就直接进入。

如果不够那说明进入有区间,注意右区间的都是 \(>mid\) 的此时必须将 \(\leq mid\) 贡献消去,并且由于天然的时间序,进入左侧的不可能也不应该贡献到这个询问。。


4-10

左方之地

这个题,,主要的key是你看到有K个不同要第一时间想起差分。

没错,现在变成每次 \(\text{xor}\) 一个 \(\text{popcount}=k\) 的数。

所有数都可以被表示成 一个集合 \(S\)\(x=\sum_{z\in S}\oplus z\)。现在是想便利这 \(2^n\) 个状态,是每一次只改变一个。

倍增构造即可,本质上实在k维空间便利,你画一画三位什么的就容易了。

[ZJOI2010] 排列计数

我们容易建出一颗限制的树。这是一个二叉树。,可以发现一个点的左子树右子树是无关的,所以限制在一个点合并两个子树,实际上就是有标号合并。如果发现这点dp显然了。


[SCOI2010]幸运数字

其实一眼容斥,我们实际上就是找出 \(S\subset U,\mathrm{lcm}(S)\) 这种东西。

实际上幸运数字是 \(O(2^l)\) 级别的。

这个只是分析,并不严谨的放缩,为我们先假设 \(lcm(a,b)=a\times b\),那么我们设这个集合里的串的长度和大概和 \(n\) 差不多,所以实际上,合法的 \(lcm(S)\) 的个数是类似划分数的,很少的。并且我们对于一种划分方式,我们构造出来的也只不过是 \(2^{l_i}\) 这种的。所以容斥其实复杂度可以接受,

现在我们只需要找出这些 \(lcm(S)\) 这个复杂度,就很迷惑了,不好分析,通过一些不那么优秀的爆搜,也可以看出实际上我们需要的 \(lcm(S)\) 甚至只有 \(10^4,10^5\) 左右的。

但是并没有题解给出非爆搜做法,我也并不会别的非爆搜做法,,,

所以只能爆搜了,。。。。爆搜最重要的trick 是,你要枚举一个上升序列 \(\prod a_i<n\) 你不如枚举一个下降序列 \(\prod a_i<n\) ,原因是你合法的时候代价一样,不合法的时候,对于一个状态肯定是前缀更有可能 \(>n\) ,所以要倒着枚举。


#6358. 前夕

这个题一言难尽呀。

我其实不是很认可一些”理所当然“的二项式反演。

所以给出一种更加复杂的做法。。。很拉。

首先我们肯定是要做 \(n\) 个元素的集合,交集大小是\(m\) 的个数,我们可以选出 \(m\) 个地方,然后问题变成了 \(n-m\) 个元素的集合,交集大小是 \(0\) 的选几个方案个数。 \[ f_n=2^{2^n}-1-\sum_{i\leq n}\binom{n}{i}f_{n-i} \] 值得注意的是 \(2^{2^n}\) 要减去1,也就是空集情况。含义就是简单的容斥。

这么求解下去肯定是没出路的,显然移项然后二项式反演。

简单推导得到 : \[ f_n=\sum_{i\leq n} \binom{n}{i}(-1)^{n-i}(2^{2^i}-1) \] 然后问题变成 \(4\mid i\) 的求解,也不难想到单位根反演。

\(2^{2^i}-1\) 形式很烂,但是我们发现有 \(-1\) 的轮换系数,实际上实在抵消的。(当然在 \(n=0\) 并不会抵消,伏笔 )

写出式子: \[ \begin{aligned} \sum_{i\leq n,4\mid n-i}\binom{n}{i}\sum_{j\leq i} \binom{i}{j}(-1)^{i-j}2^{2^j}\\ \sum_{i\leq n}\sum_{1\leq t\leq 3}\epsilon^{t(n-i)}\binom{n}{i}\sum_{j\leq i} \binom{i}{j}(-1)^{i-j}2^{2^j}\\ \sum_{1\leq t\leq 3}\sum_{j\leq n}2^{2^j}\sum_{i\geq j}\binom{n}{i} \binom{i}{j}(-1)^{i-j}\epsilon^{t(n-i)}\\ \sum_{1\leq t\leq 3}\sum_{j\leq n}2^{2^j}\sum_{i\leq n-j}\binom{n}{i+j} \binom{i+j}{j}(-1)^{i}\epsilon^{t(n-i-j)}\\ \sum_{1\leq t\leq 3}\sum_{j\leq n}2^{2^j}\binom{n}{j}\sum_{i\leq n-j}\binom{n-j}{i} (-1)^{i}\epsilon^{t(n-i-j)}\\ \sum_{1\leq t\leq 3}\sum_{j\leq n}2^{2^j}\epsilon^{t(n-j)}\binom{n}{j}((-\epsilon^{-t}){^{i}}+1)^{n-j}\\ \end{aligned} \] \(O(n)\) 计算即可,实际上这个 \(\epsilon\) 就是 \(\mathrm{i}\) ,或者说是 \(-1\)\(\bmod 998244353\) 下的平方根。原根pow一下就好。


2022-4-11 模拟赛

T2 简单的 min25筛,\(\mathrm {minp}\) 这个转移只有两条边,一种直接 \(\times\phi\) ,一种加上 \(\sigma_1\),直接维护两个东东就好了。

P.S. 递推版的min25确实慢死,我甚至怀疑他是不是 \(\mathrm{soft }\ O(n^{3/4})\) 什么的。。。

所以不如直接爆搜。。。。

T1 我觉得有点难?

排列很好说,我都看出来了逆序对是偶数是充要的,然后序列你就考虑你先把这个东西看成排列(重标号),如果本身就是偶数,必然合法,如果是奇数,也很简单,你进行一次移动 \(ab\) 但是经过 \(a\) 这种,你会发现此时逆序对 -1(1,1移动后不会贡献),所以不难发现序列一定有解。

没想出来本质上就是没看出来性质。。。。。。主要是你要发现实际上挪动两个可以看成一步一步挪动这两个,然后实际上你只不过将一个移动两步,这样你可以类似冒泡那样,把前 \(n-2\) 个冒泡排好序,那么也就剩下了最后那两个,得出逆序对为偶数,序列也好考虑类似上文那样。

剩下直接 dp 不易,但是别忘了你的系数有特点第 \(i\) 个数,只能填到 \(i+1\) 个位置,那么确定状态也简单了,你可以直接将空出的位置设入状态。

T3 鸽子了

\(\tau\)


OSU

首先拆开贡献,\(1\) 自己一组,发现 \(L^2+L\) 可以理解成 \(L\) 段内选 \(i,j(i\leq j)\) 的概率和。

所以问题转化为怎么算 \(w(i,j),([i,j]\subset [l,r])\),其中 \(w(i,j)=\prod p_k\)

题解给出了矩阵维护这个东西。。。。。。。我觉得很神。

但是实际上,区间的子区间,,这个东西可以分治(线段树),考虑线段树怎么合并即可了(分治,左节点,右节点,跨块的(lsum,rsum))。


地震后的幻想乡

先说我的另类解法。

首先我的转化是将期望转化为 概率,也就是最小生成树最大边 <=x 的概率的和。

此时问题转化为了,对于 \(x\) ,如果一条边权 \(\leq x\) 保留,否则删掉,问最后联通的概率。

我是这样想的,实际上本质不同的联通情况是少的。

我大概就是在容斥,,首先加上系数 \(\times\) 钦定一个连通块的概率 加上 系数 \(\times\) 钦定两个连通块的概率......

而钦定k个连通块的概率就是,把跨块的边只能是 [x,1] 所以贡献是 \(x^{num}\)

所以我们枚举联通情况,维护出多项式,最后积分。

只剩下如何求容斥系数了。

钦定的连通块个数 1 2 3 4
容斥系数 1 -1 2 -6

可以看出是 \((-1)^nn!\),我是考虑钦定为 \(n\) 的情况,会被 \(\begin{bmatrix}n\\j\end{bmatrix}\) 个钦定为 \(j\) 的算贡献。

所以系数的递推式: \[ \begin{aligned} f_i=-\sum f_j\times s(i,j)\\ \end{aligned} \] 不会证明。。。可能是斯特林反演惊恐


soulist做法。实际上和这个大同小异了。。。。。

我们要求出 \(\leq x\) 的连通子图概率和。这个可以DP。

\(\mathrm{dp}(s,i)\) \(s\) 表示和 \(1\) 联通的情况, \(i\) 表示这个状态选了几条边。

我们考虑容斥,先在 \(s\) 这个集合随意选边 也就是 \(\mathrm{dp(s,i)}\) 初始化为 \(\binom{edge(s)}{i}\)

然后枚举包含 \(1\) 的极大集合,减去,其中补集边随意选即可。


清新的厉害题 cf68D

不知道怎么描述。。。就说这样一个“尽管我发现了但没做出来的”observation。

\(lv<rv\) 那么说明断 \(ls\) 边的答案可以确定了,只需要进一步考察断 \(rs\) 边的答案。

反之同理,特别的 \(lv=rv\) 说明无论断 \(ls\) 还是 \(rs\) 答案都知道了。

这样随意维护课做到 查询 \(O(h^2)\) 的复杂度。。。。。


入门DS题 simple rmq

看了题解。。。。首先,经典套路是维护每一个 \(r\) 结尾的答案。

考虑一个 \(x_i\) 有贡献的区间是 \([pre_i+1,i]\) 这样的区间。当然我们需要下一个 等于 \(x_i\) 的数出现时删掉贡献。

出现的时间是一个区间。离线固然好直接时间分治。

在线吗,那就使用主席树记录一下每一个 \(r\) 的信息,然后区间修改什么的即可。(维护max,区间取 max 不用 seg beats)

复杂度 \(O(n\log^2 n)\)


随机游走相关。

  1. 设状态为到 \(x\) 停止的期望长度,容易dp
  2. 如果可以一直走,然后有一个终止位置集合,那么概率可以设成所有时刻,在这个点的概率,这样,初始起点集合只需要 讲转移式子 \(+1\) 就好。
  3. 网格图的主元法实际上,就是先进行了若干步“带入消元”,使得最后答案都表示成 主元向量的线性表示。

5,4 模拟赛 A

两个字符集 \(A,B,C\) 然后相邻不同的长度 \(2n+1\) 串使 lcs =n。

主要你要发现,两个长度为2的区间是一定有相同的字符的。

然后你大概能猜到,这样来说,存在下阶 \(n\)

然后就是如何构造的问题了。打个表,构造构造就好了。

难点在于 发现下界,以及实现上。

模拟赛B

不是很会。。。。。。。。。。。。。。。。

首先不是很懂为啥要这么考虑,,,,,,感觉很神

就是考虑 \(x\),\(y\)不合法区间的贡献。

就是把 z=lca 找出来,然后分讨不合法区间是什么,实际上就是矩形覆盖矩形查1.

然后这个矩形覆盖有特性的,他是接地,和接左的 3-side矩形。

具体问题的话,子区间就很烦,所以转化成对一维进行”扫描线“,每时每刻维护线段树,下标 \(i\) 的含义是以 \(i\) 为左端点,切右端点\(\leq T\) 的区间的答案。

不难发现此时询问变成了对上述线段树的区间询问。

那么如何维护线段树呢,实际上由于 3-side ,一种矩形可以逆着扫,然后变成区间覆盖类似的东西(因为不可能改变了)。每次只给没被覆盖的点加 1 的权值。

另外一种矩形由于有一side接左,所以有贡献的区间一定是一段前缀,这个维护最下面边,然后线段树二分即可。

现在就剩一个问题了,那我们 \(n^2\) 个区间怎么搞。

可以在 \(z\) 统计 \(x,y\) 的贡献。经典dsu on tree,你可以真的启发式合并,然后枚举小的,然后统计大的贡献。

这样区间个数也是 \(O(n\log n)\) 的。能做了。


新航线

好疲惫

新航线。

5.24模拟赛

第一题简单博弈,实际上发现白色的线性基只是后缀罢了,没有必要线性基合并等无聊的做法。

复杂度 \(O(n\log w)\)


第二题,离谱的生成函数。

很简单的dp,但是又两种写法。。。。。 \[ \begin{aligned} dp_n=\sum_{i<n}dp_idp_{n-i}\binom{n-1}{i-1}+1\\ dp_n=\frac{1}{2}\sum_{i<n}dp_idp_{n-i}\binom{n}{i}+1\\ \end{aligned} \] 第一种是钦定选第一个,第二种是算重后/2。事实上的确第二种更容易推到。

先说这种分治ntt怎么搞: \[ \begin{aligned} f_n=\sum_{i+j=n,i<n} f_ig_j \end{aligned} \] 若此时 g 不是已知而是通过 f 求出的,怎么分治ntt?

具体是: \[ \begin{aligned} l=0,&f[l,m]\oplus g[l,m]\to h[m+1,r]\\ l\not=0,&f[l,m]\oplus g[0,r-l]\to h[m+1,r]\\ &g[l,m]\oplus f[0,r-l]\to h[m+1,r] \end{aligned} \] 我们需要保证 solve(l,r)先solve(l,mid)后,l到mid是正确的。

除了最左面的那段,剩下的 mid 都应该大于 r-l。

所以最左段让他只贡献 \([0,mid],[0,mid]\) ,剩下的三端之后在贡献。

具体记忆方法是,f,g此时可以看成对称的,所以转移需要对称。


那么如何推到第一种转移的生成函数呢? \[ \frac{dp_n}{(n-1)!}=\sum\frac{dp_i}{(i-1)!}\frac{dp_{n-i}}{(n-i)!}+\frac{1}{(n-1)!} \] 或许你可能会觉得这个只不过是ogf,设生成函数不过是把ogf换下元。但是事实上

egf具有的组合含义,代数性质要比你瞎设的好得多。

\(f_n=\frac{dp_n}{n!}\)\[ \begin{aligned} nf_n=\sum if_if_{n-i}+\frac{1}{(n-1)!}\\ xF'=xF'\times F+e^xx\\ \int F'dx=\int F'\times Fdx+\int e^xdx\\ F=\frac{F^2}{2}+e^x \end{aligned} \] 解得:\(F=2-\sqrt {3-2e^x}\)

剩下的就是多项式开根了。


第三题,真拉。

首先问题就是树链 vec*mat。

做法是线段树+树剖。

发现重链剖分后实际上就有一段(最上面的)不是重链前缀。

所以你可以直接按dfn序建线段树。(线段树建树是没有常数的n,只在非叶子节点合并)

然后维护一下每个重链前缀和。

这样查询就是 \(O(q\log n l^2)\)\(\log\) 个重链,每次 \(O(l^2)\) vec*mat。

最后一个线段树分成 \(\log\) 个区间,每次 \(O(l^2)\) vec*mat。


5.31 模拟赛

T1很简单的斜率优化,一直没时间学李超树(待填),,,cdq1log,2log都能过。

T3 为什么数据结构一直没思路呀。。。。。。。。。。。。。。。。。。。。

and 和 or 运算是不太可能 O1 pushdown 计算答案之类的。

那区间修改怎么办呢?那就考虑一下势能把。

我本来傻傻的以为 and or 运算会互相改势能,现在看还是太 naiive了。

我们只考虑改一段区间一直 and 和 Or 一个数会怎样。

and 会给一个子集钦定成 0,or会给一个子集钦定成 1。

所以被钦定的子集只会单调增,这个可以被看成势能。

对于一个区间如果我们让他势能增大我们可以重构他。

那么不难想到:分块 每次会让2个散快势能发生清空 (不是整区间修改),整块就是 \(n/B\) 个每块看势能是否增大,增大就重构。

可以做到根号下log。

也可以线段树,每次会更改 \(O(\log n)\) 个区间。(势能释放),整seg区间看是否增加势能,暴力更新信息。复杂度 2log。

暴力重构看到子区间不增加势能停止即可。否则你甚至会因为常数过大 TLE。


T2,hhz说了看到100这种小范围还不会做,最优化就想flows,计数就想线代det。

我却以为这是最优化,想flows,我是傻逼。

实际上判断性要比计数更简单。

一个二分图完美匹配就是一个置换,不难想到 积和式的意义。

至于我们希望是 k 的倍数的话,就单位根反演。 \[ \begin{aligned} \sum_{p}[k|w(p)]=\sum_{p}\sum_{t<k}w_n^{t\cdot w(p)}=\sum_{t<k}\sum_{p}(w_n^t)^ {\sum c(i,p_i)}=\sum_{t<k,p}\prod (w_n^t)^{c(i,p_i)} \end{aligned} \] 较为标准的积和式。可惜的是我们并不能很快速的计算积和式。

那就那行列式当代替品。但是用行列式当代替品就会出现误判=0的情况,而且有可能是关于单位根的这个多项式是0,这很可怕。

在那行列式代替前,让我们线思考一下单位根反演的本质在干嘛?

他就是在凑系数,换言之我们把 \(w_n^t\) 拆开后乘上一些常数,这并不会影响容斥的结果。

所以我们可以随机一个矩阵 \(A\) 计算 : \[ \begin{aligned} \sum_{t<k,p}\prod A_{i,p_i}(w_n^t)^{c(i,p_i)} \end{aligned} \] 这样正确性有了保证。


dp专题还在咕咕咕。

好扯淡了。模拟赛 6.4。


本博客所有文章除特别声明外,均采用 CC BY-SA 4.0 协议 ,转载请注明出处!