先记下大佬的链接 链接
时间复杂度:o(n)
应用:比较两个环形串是否是同一字符串、判重、判同分异构等。
int get_minstring(char *s) //最小表示法
{
int len=strlen(s);
int i=0,j=1,k=0;
while(i<len&&j<len&&k<len)
{
int t=s[(i+k)%len]-s[(j+k)%len];
if(t==0)
k++;
else
{
if(t>0)
i=i+k+1;
else
j=j+k+1;
if(i==j)
j++;
k=0;
}
}
return min(i,j);
}
int get_maxstring(char *s) //最大表示法
{
int len=strlen(s);
int i=0,j=1,k=0;
while(i<len&&j<len&&k<len)
{
int t=s[(i+k)%len]-s[(j+k)%len];
if(t==0)
k++;
else
{
if(t>0)
j=j+k+1;
else
i=i+k+1;
if(i==j)
j++;
k=0;
}
}
return min(i,j);
}