您的位置:首页 > 其它

HDU 3374 String Problem (KMP+最大最小表示)

2017-08-20 22:02 399 查看

这是转载的

转载请注明出处,谢谢http://blog.csdn.net/acm_cxlove/article/details/7854526 by—cxlove

Sample 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;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: