POJ 1961 Period
训练计划KMP第一题,训练的是对KMP中前缀函数的理解。
话说这个前缀函数真是难以理解啊~~
KMP的前缀函数处理出来的前缀数组表示当当前字符失配后,要向前调到哪一个位置可以继续匹配。也就是代表着跳到的那个位置之前的所有字符与当前失配字母前的相同数量个字母是相匹配的。
题目大意:
给出一个字符串,求他之前大于1的循环节.
直接看代码吧:
#include <stdio.h> char s[1000005]; int num[1000005]; int main() { int n,case1=1; while(scanf("%d",&n),n) { scanf("%s",s); int j=-1; num[0]=-1; for(int i=0;i<n;) { if(j==-1||s[i]==s[j])num[++i]=++j; else j=num[j]; } printf("Test case #%d\n", case1++); for(int i=1;i<=n;i++) { if(i%(i-num[i])==0&&i!=(i-num[i]))printf("%d %d\n",i,i/(i-num[i])); } puts(""); } return 0; }