【loj3123】【CTS2019】重复
题目
给出一个长度为\(n\)的串\(s\),询问有多少个长度为\(m\)的串\(t\)
满足 \(t\) 的无限循环串存在一个长度为\(n\)且比\(s\)字典序严格小的子串
$ n , m \le 2000 $
题解
自从CTS打铁之后就非常自闭,智商一天不如一天,所以感觉这题异常抽象。。。
我看的这位神仙的题解
Part 1
考虑统计任意字串都大于等于的数量然后减去,首先对 $ s $ 建立 $ kmp $ 自动机
由于题目中的限制,结点 $ i $ 的出边不能比 $ i+1,nxt[i]+1,nxt[nxt[i]]+1,\cdots $ 位字符(\(fail\)链上的后一位)小
只要能在这样的自动机上走无限多次 \(t\) ,那么串 \(t\) 就是合法的
考虑状态\((i,j)\)表示自动机在结点\(i\)时,构造到了 \(t\) 的对应第\(j\)位
不同\((i,j)\)的数量也是有限的,那么一旦第二次到某个 $ (i,j) $ 的时候就出现了循环节
考虑循环节的长度为\(l\) ,显然有 \(l\) 要么是\(|s|\) 的倍数(1),要么是\(|s|\)的因数(2)
到达\((i,j)\)的最后一次一定是失配的,否则可以把循环节的起点向前移动
从 \(i\) 开头的是 \(t\) 的一个循环位移 \(t'\) , 现在如果是情况(1),设循环节为\(kt’(k>1)\),说明\(s_{1,i} + kt'\)有一个更小的循环节\(t’\),那么显然有一个更小的循环节长度为 \(|t'|\)
所以在有限步会走到一个环,且\(l\)满足(2),那就在环里不出来了=O^O=
所以一个串一定可以映射到一个环
Part 2
进一步考虑题目中的限制,相当于只有最小的那条边可能连向某个非0位置,其它的边一定连向0
记这两种边为实边和虚边,如果\(i\)的实边不连向\(i+1\),那么 \(i+1\) 到 \(n\) 就都不连通,没用了

所以自动机类似这样一个\(\rho\)形
Part 3
分开计数,考虑单独末尾的环
如果长度为\(m\)的因数那么就可以贡献长度个不同的串,否则不贡献答案
考虑经过0的环
最后的环一定是所有环在0的组合
一种顺序的环贡献就是最后一个环的长度,可以枚举一个最后一个环上的点
\(f_{i,j}\)表示从 \(0\) 走 \(i\) 步到 \(j\) 的方案,\(g_{i,j}\) 表示从 \(j\) 经 \(i\) 步沿黑边跳回 \(0\) 的方案
所以 \(ans \ = \ \sum _{i=0}^{m} \sum_{j=0}^{n} f_{i,j} \times g_{m-i,j}\)
暂时不会$n\ log n $的多项式解法
#include<bits/stdc++.h>
#define ll long long
#define mod 998244353
using namespace std;
const int N=2010;
int n,m,nxt[N],to[N],mx[N],f[N][N],g[N][N],len,pw=1;
char s[N];
void inc(int&x,int y){x+=y;if(x>=mod)x-=mod;}
int main(){
// freopen("repeat.in","r",stdin);
// freopen("repeat.out","w",stdout);
scanf("%d%s",&m,s+1);n=strlen(s+1);
for(int i=1;i<=m;++i)pw=(ll)pw*26%mod;
for(int i=2,j=0;i<=n;nxt[i++]=j){
while(j&&s[i]!=s[j+1])j=nxt[j];
if(s[i]==s[j+1])++j;
}
for(int i=0;i<=n;++i){
int k=i==n?nxt[i]:i;
mx[i]=s[to[i]=k+1]-'a';
while(k){
k=nxt[k];
if(mx[i]<s[k+1]-'a')mx[i]=s[to[i]=k+1]-'a';
}
if(to[i]!=i+1)len=i-to[n=i]+1;
}
f[0][0]=1;
for(int i=1;i<=m;++i)
for(int j=0;j<=n;++j){
inc(f[i][to[j]],f[i-1][j]);
inc(f[i][0],(ll)(25-mx[j])*f[i-1][j]%mod);
}
for(int i=0;i<=n;++i)g[1][i]=25-mx[i];
for(int i=2;i<=m;++i)
for(int j=0;j<=n;++j)g[i][j]=g[i-1][to[j]];
int ans=!(m%len)?len:0;
for(int i=0;i<=m;++i)
for(int j=0;j<=n;++j)inc(ans,(ll)f[i][j]*g[m-i][j]%mod);
cout<<(pw-ans+mod)%mod<<endl;
return 0;
}
【loj3123】【CTS2019】重复的更多相关文章
- LOJ3123 CTS2019 重复 KMP自动机、DP、多项式求逆
传送门 CTS的计数题更完辣(撒花 Orz zx2003,下面的内容在上面的博客基础上进行一定的补充. 考虑计算无限循环之后不存在子串比\(s\)字典序小的串的个数.先对串\(s\)建立KMP自动机, ...
- [LOJ3123] CTSC2019重复
Description 给定一个⻓为 n 的字符串 s , 问有多少个⻓为 m 的字符串 t 满足: 将 t 无限重复后,可以从中截出一个⻓度为 n 且字典序比 s 小的串. m ≤ 2000 n ≤ ...
- 【LOJ】#3123. 「CTS2019 | CTSC2019」重复
LOJ3123 60pts 正难则反,熟练转成总方案数减掉每个片段都大于等于s的字典序的方案 按照一般的套路建出kmp上每个点加一个字符的转移边的图(注意这个图开始字母必须是nxt链中下一个相邻的字符 ...
- 【题解】CTS2019珍珠(二项式反演+卷积)
[题解]CTS2019珍珠 题目就是要满足这样一个条件\(c_i\)代表出现次数 \[ \sum {[\dfrac {c_i } 2]} \ge 2m \] 显然\(\sum c_i=n\)所以,而且 ...
- 题解-CTS2019 珍珠
题面 CTS2019 珍珠 有 \(n\) 个在 \([1,d]\) 内的整数,求使可以拿出 \(2m\) 个整数凑成 \(m\) 个相等的整数对的方案数. 数据范围:\(0\le m\le 10^9 ...
- 避免重复造轮子的UI自动化测试框架开发
一懒起来就好久没更新文章了,其实懒也还是因为忙,今年上半年的加班赶上了去年一年的加班,加班不息啊,好了吐槽完就写写一直打算继续的自动化开发 目前各种UI测试框架层出不穷,但是万变不离其宗,驱动PC浏览 ...
- 【SQLServer】记一次数据迁移-标识重复的简单处理
汇总篇:http://www.cnblogs.com/dunitian/p/4822808.html#tsql 今天在数据迁移的时候因为手贱遇到一个坑爹问题,发来大家乐乐,也传授新手点经验 迁移惯用就 ...
- 12、Struts2表单重复提交
什么是表单重复提交 表单的重复提交: 若刷新表单页面, 再提交表单不算重复提交. 在不刷新表单页面的前提下: 多次点击提交按钮 已经提交成功, 按 "回退" 之后, 再点击 &qu ...
- 关于Android避免按钮重复点击事件
最近测试人员测试我们的APP的时候,喜欢快速点击某个按钮,出现一个页面出现多次,测试人员能不能禁止这样.我自己点击了几下,确实存在这个问题,也感觉用户体验不太好.于是乎后来我搜了下加一个方法放在我们U ...
随机推荐
- MMKV 多进程K-V组件 MD
Markdown版本笔记 我的GitHub首页 我的博客 我的微信 我的邮箱 MyAndroidBlogs baiqiantao baiqiantao bqt20094 baiqiantao@sina ...
- Unity - LayerMask简析
本文简述了LayerMask的定义,后通过项目实战充分解析 LayerMask中的GetMask.LayerToName.NameToLayer 等函数的使用方法及其注意事项. 项目地址:3D坦克大战 ...
- 在IOS10系统中无法定位问题
果是非https网页,在http协议下通过html5原生定位接口会返回错误,也就是无法正常定位到用户的具体位置,而已经支持https的网站则不会受影响. 目前提供的解决方案: 1.将网站的http设置 ...
- dump net core lldb 分析
原文https://www.cnblogs.com/calvinK/p/9274239.html centos7 lldb 调试netcore应用的内存泄漏和死循环示例(dump文件调试) 写个dem ...
- 回归写博客时间-----CeliaTodd
2019-10-17-19:28:01 记录自己的学习路程 国庆期间本来是有持续写博客的,但是有各种原因就没时间写博客了, 但是学习的进度还是没有落下的,现在正式回归写博客的时间了. 但现在不是写Py ...
- Python进阶----数据库的基础,关系型数据库与非关系型数据库(No SQL:not only sql),mysql数据库语言基础(增删改查,权限设定)
day37 一丶Python进阶----数据库的基础,mysql数据库语言基础(增删改查,权限设定) 什么是数据库: 简称:DataBase ---->DB 数据库即存放数据的仓库, ...
- 【开发笔记】- Java中关于HashMap的元素遍历的顺序问题
今天在使用如下的方式遍历HashMap里面的元素时 for (Entry<String, String> entry : hashMap.entrySet()) { MessageForm ...
- vue从零开始(二)指令
一.v-text和v-html <span v-text="msg"></span> <div v-html="html"> ...
- 珠宝juelrye宝石
juelrye n.珠宝 late 14c., juelrye "precious ornaments, jewel juelrye (uncountable) Adornment with ...
- docker复制文件到宿主机
从主机复制到容器 sudo docker cp host_path containerID:container_path 从容器复制到主机 sudo docker cp containerID:con ...