poj 2406 Power Strings(kmp循环节)
来源:互联网 发布:绘画软件价格 编辑:程序博客网 时间:2024/05/17 23:01
题目链接:http://poj.org/problem?id=2406
题目大意:如果n%(n-next[n])==0,则存在重复连续子串,长度为n-next[n]。
例如: a b a b a b
next:-1 0 0 1 2 3 4
next[n]==4,代表着,前缀abab与后缀abab相等的最长长度,这说明,ab这两个字母为一个循环节,长度=n-next[n];
1 #include <iostream> 2 #include <cstdio> 3 #include <cstring> 4 using namespace std; 5 int next[1000005],len; 6 char str[1000005]; 7 8 int get_next() 9 {10 int i=0,j=-1;11 next[0]=-1;12 while (i<len)13 {14 if (j==-1||str[i]==str[j])15 {16 i++;17 j++;18 next[i]=j;19 }20 else21 j=next[j];22 }23 }24 25 int main ()26 {27 while (scanf("%s",str)!=EOF)28 {29 if (strcmp(str,".")==0)30 break;31 len=strlen(str);32 get_next();33 if (len%(len-next[len])==0)34 printf("%d\n",len/(len-next[len]));35 else36 printf("1\n");37 }38 return 0;39 }
0 0
- POJ - 2406 Power Strings (KMP循环节)
- POJ - 2406 Power Strings(KMP 循环节)
- POJ 2406 Power Strings [KMP+循环节]
- POJ 2406 Power Strings(KMP循环节)
- poj 2406 Power Strings【kmp循环节】
- POJ 2406 Power Strings(kmp循环节)
- POJ 2406 Power Strings(KMP求最小循环节)
- poj 2406 Power Strings(kmp循环节)
- 【POJ 2406】 Power Strings(KMP求循环节)
- POJ -2406 Power Strings(循环节,kmp专题)
- [POJ 2406] Power Strings (kmp循环节)
- POJ 2406 Power Strings(KMP+最小循环节)
- POJ 2406 Power Strings (KMP) kmp循环节
- poj 2406 Power Strings (KMP+最小循环节)
- POJ 2406 Power Strings KMP 求最小循环节
- POJ 2406 Power Strings(KMP:找串循环节)
- POJ 2406 Power Strings (KMP找字符串的循环节)
- POJ 2406 Power Strings(KMP 找最短循环节)
- 最受欢迎的5个Android ORM框架
- hdu 1399 Starship Hakodate-maru (暴力搜索)
- hdu 3003 Pupu
- js字符串函数(split、join、indexOf、substring)
- hdu 4506 小明系列故事——师兄帮帮忙
- poj 2406 Power Strings(kmp循环节)
- MVC 与MVVM
- hdu 2086 A1 = ?
- hdu 3374 String Problem (kmp+最大最小表示法)
- hdu 1175 连连看 (深搜)
- 抽象问题
- hdu 2544 最短路 (dijkstra,floyd)
- 成员变量、实例变量、类变量、成员方法、实例方法、类方法的区别
- hdu 1874 畅通工程续