poj1961 Period kmp解决找字符串的最小循环节
/**
题目:poj1961 Period
链接:http://poj.org/problem?id=1961
题意:求从1到i这个前缀(2<=i<=N) ,如果有循环节(不能自身单独一个),输出前缀字符串长度以及最大的循环周期;
思路:
参考自:http://www.cnblogs.com/chenxiwenruo/p/3546457.html
定理:假设S的长度为len,则S存在最小循环节,循环节的长度L为len-next[len],子串为S[0…len-next[len]-1]。 (1)如果len%(len - next[len])==0,则表明字符串S可以完全由循环节循环组成,循环周期T=len/L。(这里的len就是从0开始的len位置,kmp也计算了next[len]。) (2)如果不能,说明还需要再添加几个字母才能补全。需要补的个数是循环个数L-len%L=L-(len-L)%L=L-next[len]%L,L=len-next[len]。 ----------------------------
*/ #include <cstdio>
#include <cstring>
#include <algorithm>
#include <set>
#include <queue>
#include <iostream>
#include <vector>
using namespace std;
#define ms(x,y) memset(x,y,sizeof x)
const int N = 1e6 + ;
const int inf = 0x3f3f3f3f;
char s[N];
int f[N];
void getFail(char* P,int* f)
{
int m = strlen(P+);
f[] = f[] = ;
for(int i = ; i <= m; i++){
int j = f[i];
while(j!=&&P[i]!=P[j]) j = f[j];
f[i+] = (P[i]==P[j])?j+:;
} }
int main()
{
int n;
int cas = ;
while(scanf("%d",&n)==&&n)
{
scanf("%s",s+);
getFail(s,f);
printf("Test case #%d\n",cas++);
for(int i = ; i <= n+; i++){
if((i--(f[i]-))==i-) continue;//不能以自身为一个循环节。即循环周期至少为2.
if((i-)%(i--(f[i]-))==){
printf("%d %d\n",i-,(i-)/(i--(f[i]-)));
}
}
puts("");
}
return ;
}
poj1961 Period kmp解决找字符串的最小循环节的更多相关文章
- codeforces 825F F. String Compression dp+kmp找字符串的最小循环节
		
/** 题目:F. String Compression 链接:http://codeforces.com/problemset/problem/825/F 题意:压缩字符串后求最小长度. 思路: d ...
 - kmp的next数组的运用(求字符串的最小循环节)
		
hdu3746 Cyclic Nacklace Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/ ...
 - POJ 2406 Power Strings(字符串的最小循环节)
		
题目链接:http://poj.org/problem?id=2406 题意:确定字符串最多是多少个相同的字串重复连接而成的 思路:关键是找到字符串的最小循环节 code: #include < ...
 - poj2185(kmp算法next数组求最小循环节,思维)
		
题目链接:https://vjudge.net/problem/POJ-2185 题意:给定由大写字母组成的r×c矩阵,求最小子矩阵使得该子矩阵能组成这个大矩阵,但并不要求小矩阵刚好组成大矩阵,即边界 ...
 - POJ2406 Power Strings —— KMP or 后缀数组 最小循环节
		
题目链接:https://vjudge.net/problem/POJ-2406 Power Strings Time Limit: 3000MS Memory Limit: 65536K Tot ...
 - Cyclic Nacklace hdu3746  kmp 最小循环节
		
题意:给出一段字符串 求最少在最右边补上多少个字符使得形成循环串(单个字符不是循环串) 自己乱搞居然搞出来了... 想法是: 如果nex[len]为0 那么答案显然是补len 否则 答案为循环 ...
 - hdu3746 Cyclic Nacklace【nxt数组应用】【最小循环节】
		
Cyclic Nacklace Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)T ...
 - next数组求最小循环节
		
1.kmp产生的next数组: 最小循环节(长度)=len-next[len]; 证明: ----------------------- ----------------------- k m ...
 - kuangbin专题16D(next求最小循环节)
		
题目链接: https://vjudge.net/contest/70325#problem/D 题意: 给出一个循环字符串, 可以在两端添加任意字符, 问最少添加多少字符可以使循环字符串变成周期循环 ...
 
随机推荐
- C++ 初始化列表(转载)
			
何谓初始化列表 与其他函数不同,构造函数除了有名字,参数列表和函数体之外,还可以有初始化列表,初始化列表以冒号开头,后跟一系列以逗号分隔的初始化字段.在 C++中,struct和class的唯一区别是 ...
 - WebService基于SoapHeader实现安全认证[webservice][.net][安全][soapheader]
			
摘 自: http://blog.sina.com.cn/s/blog_72b7a82d0100yyp8.html WebService基于SoapHeader实现安全认证[webservice][. ...
 - [Python爬虫] 之十四:Selenium +phantomjs抓取媒介360数据
			
具体代码如下: # coding=utf-8import osimport refrom selenium import webdriverimport selenium.webdriver.supp ...
 - hue启用ldap
			
[desktop] [[auth]] …… …… backend=desktop.auth.backend.LdapBackend .….. http://gethue.com/ldap-or-pam ...
 - (转)NIO 文件锁定
			
文件锁定 概述 文件锁定初看起来可能让人迷惑.它 似乎 指的是防止程序或者用户访问特定文件.事实上,文件锁就像常规的 Java 对象锁 ― 它们是 劝告式的(advisory) 锁.它们不阻止任何形式 ...
 - Zoho CEO:云计算泡沫巨大 Salesforce仅仅是新的Siebel
			
最近Zoho CEO - Sridhar Vembu接受科技博客媒体Diginomica的专訪,从独特的眼光和见解.讲述了云计算行业环境.SaaS公司的生存状态.商业观念以及Zoho的商业模式. Sr ...
 - JMeter高速应用
			
过去长期用loadrunner做性能測试.可是渐渐认为有些麻烦了: 1.仅仅能执行在windows环境下,而生产环境差点儿清一色的linux.为了在同一网段做性能或压力測试,还须要单独部署一套wind ...
 - C# 操作ini配置文件
			
最近使用Winform做一个小系统,由于需要保存一些默认配置项.自然就想到了轻量级的配置文件类型ini.在此也分享和记录一下实现方式,方便以后查询和使用. 废话不多说上代码: 实现公共函数↓ publ ...
 - 利用email.net设置网络代理发邮件
			
近期在做一个项目,客户的内部网络须要设置代理才干收发邮件,本来一个简单的东西突然变得复杂了,在baidu搜索了非常久都没找到适合的组件.baidu就像个废物一样,没办法仅仅能去yahoo搜,结果在微软 ...
 - 【征文】Hadoop十周年特别策划——我与Hadoop不得不说的故事
			
2016年是Hadoop的十周年生日,在今年,CSDN将以技术和实战为主题与大家共同为Hadoop庆生.其主要内容包含Hadoop专业词典.系列视频技术解析.Hadoop行业实践.线上问答.线下沙龙. ...