HDU:1358-Period
Period
Time Limit: 2000/1000 MS (Java/Others) 
Memory Limit: 65536/32768 K (Java/Others)
Problem Description
For each prefix of a given string S with N characters (each character has an ASCII code between 97 and 126, inclusive), we want to know whether the prefix is a periodic string. That is, for each i (2 <= i <= N) we want to know the largest K > 1 (if there is one) such that the prefix of S with length i can be written as AK , that is A concatenated K times, for some string A. Of course, we also want to know the period K.
Input
The input file consists of several test cases. Each test case consists of two lines. The first one contains N (2 <= N <= 1 000 000) – the size of the string S. The second line contains the string S. The input file ends with a line, having the number zero on it.
Output
For each test case, output “Test case #” and the consecutive test case number on a single line; then, for each prefix with length i that has a period K > 1, output the prefix size i and the period K separated by a single space; the prefix sizes must be in increasing order. Print a blank line after each test case.
Sample Input
3  
aaa  
12  
aabaabaabaab  
0
Sample Output
Test case #1  
2 2  
3 3
Test case #2  
2 2  
6 2  
9 3  
12 4
解题心得:
- 题意就是叫你找给出的字符串的每一个前缀中存在的循环节,其实很简单,就是在建立next数组的时候一边匹配,一边寻找循环节。裸找循环节。
#include<stdio.h>
#include<cstring>
using namespace std;
const int maxn = 1e6+100;
char s[maxn];
int next[maxn],n,t;
void cal_next()
{
    memset(next,-1,sizeof(next));
    next[0] = -1;
    int k = -1;
    for(int i=1;i<n;i++)
    {
        while(k > -1 && s[i] != s[k+1])
            k = next[k];
        if(s[i] == s[k+1])
            k++;
        next[i] = k;
        if(k == -1)//当是-1的时候肯定没有循环节
            continue;
        int len = i+1;
        if(len%(i-k) == 0)
            printf("%d %d\n",len,len/(i-k));
    }
    printf("\n");
}
int main()
{
    t = 1;
    while(scanf("%d",&n) && n)
    {
        scanf("%s",s);
        printf("Test case #%d\n",t++);
        cal_next();
    }
}
HDU:1358-Period的更多相关文章
- HDU 5908 Abelian Period (BestCoder Round #88 模拟+暴力)
		HDU 5908 Abelian Period (BestCoder Round #88 模拟+暴力) 题目链接http://acm.hdu.edu.cn/showproblem.php?pid=59 ... 
- hdu 1358 Period  最小循环节
		题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1358 分析:已知字符串,求其由最小循环节构成的前缀字符串. /*Period Time Limit: ... 
- HDU 3746 - Cyclic Nacklace & HDU 1358 - Period - [KMP求最小循环节]
		题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3746 Time Limit: 2000/1000 MS (Java/Others) Memory Li ... 
- hdu 1358 Period
		题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1358 思路:Next数组的用法,在第i个位置上如果有i%(i-Next[i])==0的话最小循环节就是 ... 
- HDU 1358 Period KMP
		题目地址: http://acm.hdu.edu.cn/showproblem.php?pid=1358 求周期问题,简单KMP—— AC代码: #include <iostream> # ... 
- HDU 1358 Period(KMP计算周期)
		题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1358 题目大意:给你一串字符串,判断字符串的前缀是否由某些字符串多次重复而构成. 也就是,从第1个字母 ... 
- KMP + 求最小循环节 --- HDU 1358 Period
		Period Problem's Link: http://acm.hdu.edu.cn/showproblem.php?pid=1358 Mean: 给你一个字符串,让你从第二个字符开始判断当前长度 ... 
- Hdu 1358 Period (KMP 求最小循环节)
		题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1358 题目描述: 给出一个字符串S,输出S的前缀能表达成Ak的所有情况,每种情况输出前缀的结束位置和 ... 
- HDU 1358 Period (kmp判断循环子串)
		Period Time Limit : 2000/1000ms (Java/Other) Memory Limit : 65536/32768K (Java/Other) Total Submis ... 
- HDU 1358 Period 求前缀长度和出现次数(KMP的next数组的使用)
		Period Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Subm ... 
随机推荐
- CentOS7.4搭建GitLab
			1.查看服务器环境 uname -a 2.下载安装包 [1]找到相应的最新版本的下载路径 网址:https://mirrors.tuna.tsinghua.edu.cn/gitlab-ce/yum/e ... 
- Vmware 可用的激活码
			4F207-8HJ1M-WZCP8-000N0-92Q6G 0A6Z5-8H1EJ-WZCL1-PK072-23DJG 0F0Q9-8F38L-RZXT9-4U054-ACW5F JA02E-09H4 ... 
- 【问题记录】mysql TIMEDIFF 和 TIMESTAMPDIFF的使用
			今天遇到一个需求,需要计算数据表中两个时间的差值,并取对应的秒数 一开始我是用 time_to_sec(timediff (time1,time2)) 但是这样会有一个问题,,,时间短的用这个计算没有 ... 
- hibernate课程 初探单表映射2-7 hbm配置文件常用设置
			本节主要简介hbm配置文件以下内容: 1 mapping标签 2 class标签 3 id标签 1 hibbernate-mapping标签 schema 模式名称 catalog 目录名称 defa ... 
- 在Magento System Configuration页面添加配置项
			以 Jp_Coupon 模块为例: 目标: 在 System configuration 页面添加一个 JP tab, 在JP中添加 Coupon section, 然后给 Coupon sectio ... 
- Oracle 11g服务详细介绍
			按照windows 7 64位 安装oracle 11g R2中的方法成功安装Oracle 11g后,共有7个服务,这七个服务的含义分别为: 1. Oracle ORCL VSS Writer Ser ... 
- javascript设计模式之装饰者模式
			/* * 装饰者模式提供比继承更有弹性的替代方案 * 在不改变原构造函数的情况下,添加新的属性或功能 */ //需要装饰的类(函数) function Macbook() { this.cost = ... 
- SqlServer Alwayson主副本图标显示问号的原因
			搭建完alwayson后,登录辅助副本服务器,查看alwayson可用性副本列表,看到主副本前面显示了一个问号,这里借用网上一张图片做展示: 在显示问号的主副本上右键属性查看,“角色”一栏中,显示的是 ... 
- hdu-1179 Ollivanders: Makers of Fine Wands since 382 BC.---二分图匹配模板
			题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1179 题目大意: 有n个人要去买魔杖,有m根魔杖(和哈利波特去买魔杖的时候一样,是由魔杖选人).接下 ... 
- Being a Good Boy in Spring Festival(博弈)
			Being a Good Boy in Spring Festival Problem Description一年在外 父母时刻牵挂春节回家 你能做几天好孩子吗寒假里尝试做做下面的事情吧 陪妈妈逛一次 ... 
