zoukankan      html  css  js  c++  java
  • POJ-2752-Seek the Name(KMP, 循环节)

    链接:

    https://vjudge.net/problem/POJ-2752#author=0

    题意:

    给定若干只含小写字母的字符串(这些字符串总长≤400000),在每个字符串中求出所有既是前缀又是后缀的子串长度。

    例如:ababcababababcabab,既是前缀又是后缀的子串:ab,abab,ababcabab,ababcababababcabab。

    思路:

    从最后开始, 先求出1-len的前缀等于后缀部分, 因为这个前缀等于后缀, 所以再在前缀上找满足条件即可.不断递归, 直到找不到为止.

    代码:

    #include <iostream>
    #include <cstdio>
    #include <cstring>
    #include <vector>
    //#include <memory.h>
    #include <queue>
    #include <set>
    #include <map>
    #include <algorithm>
    #include <math.h>
    #include <stack>
    #include <string>
    #include <assert.h>
    #include <iomanip>
    #include <iostream>
    #include <sstream>
    #define MINF 0x3f3f3f3f
    using namespace std;
    typedef long long LL;
    const int MAXN = 1e6+10;
    
    int Next[MAXN];
    char s[MAXN], p[MAXN];
    
    void GetNext()
    {
        int len = strlen(p);
        Next[0] = -1;
        int j = 0;
        int k = -1;
        while (j < len)
        {
            if (k == -1 || p[k] == p[j])
            {
                ++k;
                ++j;
                Next[j] = k;
            }
            else
                k = Next[k];
        }
    }
    
    int main()
    {
        while (~scanf("%s", p))
        {
            GetNext();
            stack<int> St;
            St.push((int)strlen(p));
            int len = strlen(p);
            while (Next[len] != 0)
            {
                St.push(Next[len]);
                len = Next[len];
            }
            while (!St.empty())
            {
                printf("%d ", St.top());
                St.pop();
            }
            puts("");
        }
    
        return 0;
    }
    
  • 相关阅读:
    分享一个详情页
    ES6初探,变量的声明
    ES6初探,什么是ES6
    提问回顾
    个人阅读&个人总结
    结对项目-数独程序扩展
    个人作业Week3-案例分析
    个人作业Week2-代码复审
    个人作业1
    【个人项目】数独
  • 原文地址:https://www.cnblogs.com/YDDDD/p/11579389.html
Copyright © 2011-2022 走看看