HDU 3374 String Problem (KMP+最大最小表示)
2017-08-20 22:02
399 查看
这是转载的
转载请注明出处,谢谢http://blog.csdn.net/acm_cxlove/article/details/7854526 by—cxloveSample Input
abcder
aaaaaa
ababab
Sample Output
1 1 6 1
1 6 1 6
1 3 2 3
题目:输出最大最小表示是从哪一位开始,而且输出数量
感悟:原来最大表示和最小表示差不多。这个说的很好;
#include<iostream> #include<cstdio> #include<cstring> #include<cmath> #define N 1000005 using namespace std; char str ; int next ; void get_next(char *s,int len){ next[0]=-1; int i=0,j=-1; while(i<len){ if(j==-1||s[i]==s[j]){ i++;j++; if(s[i]==s[j])next[i]=next[j]; else next[i]=j; } else j=next[j]; } } int min_max_express(char *s,int len,bool flag){ int i=0,j=1,k=0; while(i<len&&j<len&&k<len){ int t=s[(j+k)%len]-s[(i+k)%len]; //二者相等,后移 if(t==0) k++; else{ if(flag){ if(t>0) j+=k+1; else i+=k+1; } else{ if(t>0) i+=k+1; else j+=k+1; } if(i==j) j++; k=0; } } return min(i,j); } int main(){ while(scanf("%s",&str)!=EOF){ int len=strlen(str); int min_express=min_max_express(str,len,true); int max_express=min_max_express(str,len,false); get_next(str,len); int l=len-next[len]; int ans=len%l?1:len/l; printf("%d %d %d %d\n",min_express+1,ans,max_express+1,ans); } return 0; }
相关文章推荐
- hdu 3374 String Problem (kmp+最大最小表示法)
- HDU 3374 String Problem (KMP+最大最小表示)
- HDU 3374 String Problem (KMP+最大最小表示)
- hdu 3374 String Problem(字符串最小最大表示法+kmp)
- hdu 3374 String Problem (字符串最小最大表示 + KMP求循环节)
- String Problem - HDU 3374 (kmp+最大最小表示)
- HDU 3374 String Problem (KMP+最大最小表示)
- HDU 3374 String Problem(KMP求周期+求串最大最小表示法)
- HDU 3374 String Problem (KMP+最大最小表示)
- HDU 3374 String Problem (KMP+最大最小表示)
- hdu 3374 String Problem (kmp+最大最小表示法)
- hdu 3374 String Problem(KMP+字符串最小最大表示)
- HDU 3374 String Problem (KMP+最大最小表示)
- HDU 3374 String Problem(最大最小表示法模板+KMP+next数组的运用)
- HDU 3374 String Problem (KMP+最大最小表示法)
- HDU 3374 String Problem (KMP+最小最大表示)
- HDU 3374 String Problem(最小表示法·KMP)
- HDU 3374 String Problem(最小(大)表示 + KMP)
- HDU 3374 KMP 最大表示法 最小表示法
- 【KMP】 HDU 3374 String Problem 最小表示法