传送门


CTS的计数题更完辣(撒花

Orz zx2003,下面的内容在上面的博客基础上进行一定的补充。

考虑计算无限循环之后不存在子串比\(s\)字典序小的串的个数。先对串\(s\)建立KMP自动机,那么对于点\(i\)连出的所有边,只有不是回到起点的字符最大的那条边以及字符比它大的走向起点的边可以走,因为如果走其他边,那么当前匹配的串就会存在一个后缀比\(s\)字典序小。

经过这样的删边后,对于每一个点只有两种边,一种是去往另一个点的边,一种是去往起点的边。如果不考虑去往起点的边,与起点连通的连通块刚好构成一个rho的形状(也就是\(\rho\),即一条从起点开始的链,链底是一个环)。我们考虑在这个rho上计数。

不妨设当前构造的满足条件的串是串\(t\)。有一个引理:设\(a_0 = 0\),\(a_i =\)从KMP自动机上的\(a_{i-1}\)号点开始匹配串\(t\)走到的位置,可以得到一个长度无限的序列\(a\),在序列\(a\)上必定存在一个位置\(x\)满足\(\forall y > x , a_y = a_x\)。

证明:\(a_x\)实质上就是把\(x\)个\(t\)串拼在一起放在KMP自动机上匹配最后到达的节点。因为如果\(t\)合法,那么\(t\)只会走每个点字符最大的一条边和比这个字符更大的回到起点的边,所以将\(x\)个\(t\)串放在现在的KMP自动机上匹配等价于将\(x\)个\(t\)串放在没有删边之前的KMP自动机上匹配,而在后者意义下匹配完到达的节点表示\(x\)个\(t\)串的最长后缀满足它是\(s\)的前缀。当\(x|t|>|s|\),因为在后面加上一个\(t\)相当于在前面加上一个\(t\),而此时加上一个\(t\)不可能对最长后缀的长度产生影响,所以再加上一个\(t\)进行匹配,仍会匹配到之前的节点。

显然这个匹配到的节点是唯一的,所以我们可以枚举这个节点,那么我们需要求的就是长度为\(m\)的路径条数满足起点和终点都是这一个点。

如果从一个节点开始匹配串\(t\),没有经过起点回到自己,那么一定是在rho上转,方案数唯一。

接下来考虑回到起点的情况。考虑一个dp:设\(f_{i,j}\)表示从起点开始走\(i\)步走到节点\(j\)的方案数,这个可以直接做。接下来我们枚举从这个节点沿着\(\rho\)走了多少步回到根,用回到根的方案数乘上从起点经过若干步到达当前节点的方案数贡献答案。

总复杂度\(O(n^2)\)。

接下来使用多项式运算优化上面后半部分计算的复杂度。

上面枚举的路径相当于三个过程:从当前节点开始走到起点->走若干次起点到起点的路径->从起点走到当前节点停下来,而第一个过程和第三个过程合起来等价于先枚举一个从起点开始走回起点的路径,然后再在这条路径上选择一个点作为匹配终点。那么先枚举这条路径,对于一条长度为\(x\)的路径,就有\(x\)种选择匹配终点的方式。

不妨设\(F = \sum\limits_{i=1}^\infty f_ix^i\),其中\(f_i\)表示从起点开始走\(i\)步走回到起点的方案数,这个可以在KMP自动机建立之后计算。那么枚举第一个过程和第三个过程的路径的并,方案数的多项式就是\(x F'\)。接下来再枚举经过了多少次起点,需要乘上多项式\(\sum\limits_{i=0}^\infty F^i = \frac{1}{1 - F}\),那么最终的答案就是\([x^m] (xF' \times \frac{1}{1 - F} + 1)\),最后加上的\(1\)是一个余项。

代码:\(O(n^2)\)

代码:\(O(nlogn)\)

LOJ3123 CTS2019 重复 KMP自动机、DP、多项式求逆的更多相关文章

  1. CF848E Days of Floral Colours——DP+多项式求逆/分治NTT

    官方题解:http://codeforces.com/blog/entry/54233 就是由简入繁 1.序列处理,只考虑一个半圆 2.环形处理(其实这个就是多了旋转同构) 然后基于分割线邻居的跨越与 ...

  2. BZOJ 3456: 城市规划(dp+多项式求逆)

    传送门 解题思路 这道题就是求带标号的无向连通图个数,首先考虑\(O(n^2)\)的做法,设\(f_i\)表示有\(i\)个节点的无向连通图个数,那么考虑容斥,先把所有的无向图求出,即为\(2^{C( ...

  3. 【bzoj3456】城市规划 dp+多项式求逆

    Description 刚刚解决完电力网络的问题, 阿狸又被领导的任务给难住了. 刚才说过, 阿狸的国家有n个城市, 现在国家需要在某些城市对之间建立一些贸易路线, 使得整个国家的任意两个城市都直接或 ...

  4. BZOJ 3456: 城市规划 与 多项式求逆算法介绍(多项式求逆, dp)

    题面 求有 \(n\) 个点的无向有标号连通图个数 . \((1 \le n \le 1.3 * 10^5)\) 题解 首先考虑 dp ... 直接算可行的方案数 , 容易算重复 . 我们用总方案数减 ...

  5. 【bzoj3456】城市规划(多项式求逆+dp)

    Description 求\(~n~\)个点组成的有标号无向连通图的个数.\(~1 \leq n \leq 13 \times 10 ^ 4~\). Solution 这道题的弱化版是poj1737, ...

  6. [BZOJ 3625] [Codeforces 438E] 小朋友的二叉树 (DP+生成函数+多项式开根+多项式求逆)

    [BZOJ 3625] [Codeforces 438E] 小朋友的二叉树 (DP+生成函数+多项式开根+多项式求逆) 题面 一棵二叉树的所有点的点权都是给定的集合中的一个数. 让你求出1到m中所有权 ...

  7. Luogu4233 射命丸文的笔记 DP、多项式求逆

    传送门 注意到总共有\(\frac{n!}{n}\)条本质不同的哈密顿回路,每一条哈密顿回路恰好会出现在\(2^{\binom{n}{2} - n}\)个图中,所以我们实际上要算的是强连通有向竞赛图的 ...

  8. [BZOJ3456]城市规划:DP+NTT+多项式求逆

    写在前面的话 昨天听吕老板讲课,数数题感觉十分的神仙. 于是,ErkkiErkko这个小蒟蒻也要去学数数题了. 分析 Miskcoo orz 带标号无向连通图计数. \(f(x)\)表示\(x\)个点 ...

  9. bzoj 3456 城市规划——分治FFT / 多项式求逆 / 多项式求ln

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3456 分治FFT: 设 dp[ i ] 表示 i 个点时连通的方案数. 考虑算补集:连通的方 ...

随机推荐

  1. vue-cli之路由独立成JS文件之后,如何在路由中获取vuex属性或者设置国际化i18n的当前使用语言

    国际化vue-i18n的使用: import Vue from 'vue'; import VueI18n from 'vue-i18n'; // 引入语言包 import zh from '@/co ...

  2. HTML试题解析

    1.关于CSS为什么会出现Bug说法不正确的是(). (选择二项) A:编写CSS样式时需要考虑在不同浏览器中实现表现一致 B:各大主流浏览器由于不同厂家开发,浏览器使用的内核不同,支持CSS的程度不 ...

  3. 「2019-8-13提高模拟赛」树 (tree)

    传送门 Description 你有一个 \(n\)个点的树,第 \(i\)个点的父亲是\(p_i\).每个点有一个权值 \(t_i\) 和一个颜色黑或者白.所有点一开始都是白色. 你要进行 \(m\ ...

  4. msyql8.0编译安装

    1.安装依赖 yum  -y install wget  cmake gcc gcc-c++ncurses  ncurses-devel  libaio-devel openssl openssl-d ...

  5. Echarts 入门操作

    Echarts具有丰富的图表,可以说是数据可视化的神器: 1.下载Echarts 到官网或者点击以下文字[下载Echarts]即可下载: ①官网下载地址:https://echarts.baidu.c ...

  6. 剑指offer:丑数

    题目描述: 把只包含质因子2.3和5的数称作丑数(Ugly Number).例如6.8都是丑数,但14不是,因为它包含质因子7. 习惯上我们把1当做是第一个丑数.求按从小到大的顺序的第N个丑数. 解题 ...

  7. excel矩阵运算操作-转置 行列式 相乘 逆阵

    excel矩阵运算操作-转置 行列式 相乘 逆阵 https://jingyan.baidu.com/article/154b463128e13928ca8f41a4.html Excel中矩阵的相关 ...

  8. Buffon投针问题

  9. JS高级:面向对象解析

    1 实例属性/方法 都是绑定在使用构造函数创建出来的对象p上; 最终使用的时候也是使用对象p来进行访问; function Person(name, age, doFunc) { this.name ...

  10. 查看appPackage和appActivity的多种方法

    一.通过adb shell 查看 adb shell dumpsys activity | grep 包名 列如: C:\Users\admin>adb shell root@shamu:/ # ...