FZU 1901 Period II(KMP循环节+公共前后缀)
题目链接:http://acm.fzu.edu.cn/problem.php?pid=1901
题目大意:题目大意求出所有p满足s[i]=s[i+p](i<=len-p)
解题思路:
其实就是要找出所有的循环节(不只是最小的),
循环节本质跟公共前后缀有关,可以通过递归的方法求出所有公共前后缀ti,那么len-ti就是相应循环节。
之前写的计算最小循环节,累加循环节得到前缀的方法是有问题的,过不了下面这种数据。
数据:abacaba
结果应该是4,6,7
而求出来的是4,7。因为忽略了除了最小循环节外的其他循环节。
代码
1 #include<iostream> 2 #include<cstdio> 3 #include<cstring> 4 #include<algorithm> 5 using namespace std; 6 const int N=1e6+5; 7 8 int len; 9 int nxt[N],ans[N]; 10 char p[N]; 11 12 void getnext(){ 13 int i=0,j=nxt[0]=-1; 14 while(i<len){ 15 while(j!=-1&&p[i]!=p[j]) 16 j=nxt[j]; 17 nxt[++i]=++j; 18 } 19 } 20 21 int main(){ 22 int t,cas=0; 23 scanf("%d",&t); 24 while(t--){ 25 scanf("%s",p); 26 len=strlen(p); 27 getnext(); 28 int t=nxt[len]; 29 int cnt=0; 30 while(t!=-1){ 31 if(t>=0) ans[cnt++]=len-t; 32 t=nxt[t]; 33 } 34 printf("Case #%d: %d\n",++cas,cnt); 35 for(int i=0;i<cnt;i++){ 36 printf("%d%c",ans[i],i==cnt-1?'\n':' '); 37 } 38 } 39 return 0; 40 }
标签:
KMP
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core GC计划阶段(plan_phase)底层原理浅谈
· .NET开发智能桌面机器人:用.NET IoT库编写驱动控制两个屏幕
· 用纯.NET开发并制作一个智能桌面机器人:从.NET IoT入门开始
· 一个超经典 WinForm,WPF 卡死问题的终极反思
· ASP.NET Core - 日志记录系统(二)
· 博客园 & 1Panel 联合终身会员上线
· 支付宝事故这事儿,凭什么又是程序员背锅?有没有可能是这样的...
· https证书一键自动续期,帮你解放90天限制
· 告别虚拟机!WSL2安装配置教程!!!
· 在线客服系统 QPS 突破 240/秒,连接数突破 4000,日请求数接近1000万次,.NET 多