• POJ2406(next原理理解)


    Power Strings
    Time Limit: 3000MS   Memory Limit: 65536K
    Total Submissions: 40448   Accepted: 16828

    Description

    Given two strings a and b we define a*b to be their concatenation. For example, if a = "abc" and b = "def" then a*b = "abcdef". If we think of concatenation as multiplication, exponentiation by a non-negative integer is defined in the normal way: a^0 = "" (the empty string) and a^(n+1) = a*(a^n).

    Input

    Each test case is a line of input representing s, a string of printable characters. The length of s will be at least 1 and will not exceed 1 million characters. A line containing a period follows the last test case.

    Output

    For each s you should print the largest n such that s = a^n for some string a.

    Sample Input

    abcd
    aaaa
    ababab
    .
    

    Sample Output

    1
    4
    3
    #include<cstdio>
    #include<cstring>
    #include<algorithm>
    using namespace std;
    const int MAXN=1000005;
    char s[MAXN];
    int len;
    int next[MAXN];
    void getnext()
    {
        int i=0,k=-1;
        next[0]=-1;
        while(i<len)
        {
            if(k==-1||s[i]==s[k])
            {
                i++;
                k++;
                next[i]=k;
            }
            else    k=next[k];
        }
    }
    int main()
    {
        while(gets(s)&&*s!='.')
        {
            len=strlen(s);
            getnext();
            int ans=1;
            if(len%(len-next[len])==0)    ans=len/(len-next[len]);
            printf("%d
    ",ans);
        }
        
        return 0;
    }
  • 相关阅读:
    mysql-day06
    C语言 输出二进制数
    Python学习笔记(一)
    数组指针与指针数组
    重装系统--小白版
    Java 面对对象阶段练手项目【飞机大战】
    Java环境的配置
    在Linux环境下运行C语言程序
    Torrent文件
    ubuntu下载速度慢的解决办法--修改下载源
  • 原文地址:https://www.cnblogs.com/program-ccc/p/5203745.html
Copyright © 2020-2023  润新知