首页 > 其他 > 详细

最小循环节(求长度)

时间:2015-07-22 12:19:38      阅读:237      评论:0      收藏:0      [点我收藏+]

Description

There is a string A. The length of A is less than 1,000,000. I rewrite it again and again. Then I got a new string: AAAAAA...... Now I cut it from two different position and get a new string B. Then, give you the string B, can you tell me the length of the shortest possible string A. For example, A="abcdefg". I got abcd efgabcdefgabcdefgabcdefg.... Then I cut the red part: efgabcdefgabcde as string B. From B, you should find out the shortest A.

Input

Multiply Test Cases. For each line there is a string B which contains only lowercase and uppercase charactors. The length of B is no more than 1,000,000.

Output

For each line, output an integer, as described above.

Sample Input

bcabcab
efgabcdefgabcde

Sample Output

3
7
#include <stdio.h>
#include <string.h>
using namespace std;
const int maxn=1000010;
char t[maxn];
int n[maxn];
int len;
void get_next()
{
    int i=0;
    int j=-1;
    n[0]=-1;
    while(i<len)
    {
        if(j==-1||t[i]==t[j])
        {
            i++;
            j++;
            n[i]=j;
        }
        else
            j=n[j];
    }
}
int main()
{
    while(scanf("%s",t)!=EOF)
    {
        int j,i;
        len=strlen(t);
        memset(n,0,sizeof(n));
        get_next();
       printf("%d\n",len-n[len]);
    }
    return 0;
}

 

最小循环节(求长度)

原文:http://www.cnblogs.com/tianmin123/p/4666863.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!