zoukankan      html  css  js  c++  java
  • Power Strings POJ

    Power Strings

    POJ - 2406
    时限: 3000MS   内存: 65536KB   64位IO格式: %I64d & %I64u

     状态

    已开启划词翻译

    问题描述

    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).

    输入

    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.

    输出

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

    样例输入

    abcd
    aaaa
    ababab
    .
    

    样例输出

    1
    4
    3
    

    提示

    This problem has huge input, use scanf instead of cin to avoid time limit exceed.

    来源

    题意:一个字符串可以由其循环节循环n次得到,问n最大可以是多少……
    kmp练习。
     1 #include <iostream>
     2 #include <cstdio>
     3 #include <cstring>
     4 
     5 using namespace std;
     6 
     7 #define maxn 10000008
     8 
     9 char s[maxn];
    10 int next[maxn];
    11 
    12 void getNext()
    13 {
    14     int j, k, i;
    15     i = strlen(s);
    16 
    17     j = 0;
    18     k = -1;
    19     next[0] = -1;
    20     while(j < i)
    21     {
    22         if(k == -1 || s[j] == s[k])
    23         {
    24             j++;
    25             k++;
    26             next[j] = k;
    27         }
    28         else
    29             k = next[k];
    30     }
    31 }
    32 
    33 int main()
    34 {
    35     while(1)
    36     {
    37         scanf("%s", s);
    38         if(s[0] == '.')
    39             break;
    40 
    41         int q = strlen(s);
    42 
    43         memset(next, 0, sizeof(next));
    44         getNext();
    45 
    46         int k = next[q];   // k表示s串 q位置的最长的前缀和后缀相等的长度。q-k代表最小循环节的长度
    47 
    48         if(q % (q - k) == 0)  // q-k就是最小循环节的长度
    49             printf("%d
    ", q / (q - k));
    50         else
    51             printf("1
    ");
    52     }
    53     return 0;
    54 }
  • 相关阅读:
    二叉搜索树的java实现
    HashMap源码分析
    集合之LinkedList源码分析
    集合之ArrayList的源码分析
    CountDownLatch源码解析
    部署java项目到阿里云服务器(centos7版本)
    并发中的单例模式
    AbstractQueuedSynchronizer的简单分析
    ThreadPoolExecutor的分析(二)
    ThinkPHP5 与 ThinkPHP3.* 之间的使用差异
  • 原文地址:https://www.cnblogs.com/Tinamei/p/4802846.html
Copyright © 2011-2022 走看看