首页 > 代码库 > poj2406 Power Strings (KMP)
poj2406 Power Strings (KMP)
这题跟HDU 1358 Period (KMP)差不多,稍微修改代码就行了。
关于KMP的更多知识,请关注从头到尾彻底理解KMP(2014年8月4日版)。
#include<stdio.h> #include<string.h> int n,next[1000000]; char p[1000000]; void getnext() { int k=0,j=1; next[0]=-1;next[1]=0; while (j<n) { if (k==-1||p[j]==p[k]) { k++;j++; next[j]=k; } else k=next[k]; } } void kmp() { int t; t=n-next[n]; if(n%t==0&&n/t>1) printf("%d\n",n/t); else printf("1\n"); } int main() { while (scanf("%s",p)&&p[0]!='.') { n=strlen(p); getnext(); kmp(); } return 0; }
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。