(字符串的模式匹配4.7.18)POJ 2406 Power Strings(求一个字符串的最小重复串)
注意,在IDE运行时,可能会因为开的数组太大而报错,这时我们可以把数组开小一点来进行调试....提交的时候把数组的大小改成1000005即可。。。。
#include <iostream>
#include <cstdio>
#include <cstring> using namespace std; const int maxn = 1000005; int main() {
char str[maxn];
while (scanf("%s", str) != EOF) { if (str[0] == '.') {
break;
}
int len = strlen(str); int suffix[maxn + 1]; //应用KMP算法计算单词w的前缀函数
suffix[0] = -1;
suffix[1] = 0;
int cur, p = 0;
for (cur = 2; cur <= len; ++cur) {//这里的len不要写成strlen(str),这样可能会导致超时
while (p >= 0 && str[p] != str[cur - 1]) {
p = suffix[p];
} suffix[cur] = ++p;
} //如果len是(len - suffix[len])的前缀,即,假如当前的重复串的长度能被原串的长度整除...
if((len % (len - suffix[len])) == 0){
printf("%d\n", (len / (len - suffix[len])));
}else{
printf("1\n");
} } return 0;
}
(字符串的模式匹配4.7.18)POJ 2406 Power Strings(求一个字符串的最小重复串)的更多相关文章
- poj 2406 Power Strings 后缀数组解法
		
连续重复子串问题 poj 2406 Power Strings http://poj.org/problem?id=2406 问一个串能否写成a^n次方这种形式. 虽然这题用kmp做比较合适,但是我们 ...
 - KMP POJ 2406 Power Strings
		
题目传送门 /* 题意:一个串有字串重复n次产生,求最大的n KMP:nex[]的性质应用,感觉对nex加深了理解 */ /************************************** ...
 - POJ 2406 Power Strings (KMP)
		
Power Strings Time Limit: 3000MSMemory Limit: 65536K Total Submissions: 29663Accepted: 12387 Descrip ...
 - poj 2406 Power Strings (kmp 中 next 数组的应用||后缀数组)
		
http://poj.org/problem?id=2406 Power Strings Time Limit: 3000MS Memory Limit: 65536K Total Submiss ...
 - KMP + 求最小循环节 --- POJ 2406 Power Strings
		
Power Strings Problem's Link: http://poj.org/problem?id=2406 Mean: 给你一个字符串,让你求这个字符串最多能够被表示成最小循环节重复多少 ...
 - poj 2406 Power Strings(kmp next的应用)
		
题目链接:http://poj.org/problem?id=2406 题意:就是求一个字符串最多有几个相同的小字符串组成. 题解:直接求一下next然后找到长度,长度就是len-1-next[len ...
 - poj 2406 Power Strings【字符串+最小循环节的个数】
		
Po ...
 - poj 2406 Power Strings(kmp应用)
		
题目链接:http://poj.org/problem?id=2406 题意:给出一个字符串s,求重复子串出现的最大次数. 分析:kmp的next[]数组的应用. 要求重复子串出现的最大次数,其实就是 ...
 - 【kmp+最小循环节】poj 2406 Power Strings
		
http://poj.org/problem?id=2406 [题意] 给定字符串s,s=a^n,a是s的子串,求n最大是多少 [思路] kmp中的next数组求最小循环节的应用 例如 ababab ...
 
随机推荐
- js时间日期转时间戳
			
var contractstarttimea='2016-01-01'; var contractendtimea='2016-05-01'; var contractstart = Date.par ...
 - 【原创】用python实现shell的tail操作
			
在工作过程中发现监控实时刷新文件时,不是那么的任性. 故结合shell中的tail,做了一个类似tail的python脚本. 详情如下: #!/usr/bin/env python #coding=u ...
 - 《C++ primer》--第10章
			
习题10.21 解释map和set容器的差别,以及他们各自适用的情况. 解答: map容器和set容器的差别在于: map容器是键-值对的集合,而set容器只是键的集合: map类型适用于需要了解键与 ...
 - 如何设置适当的ramp-up period值
			
如何设置适当的值并不轻易. 首先,假如要使用大量线程的话,ramp-up period 一般不要设置成零. 因为假如设置成零,Jmeter将会在测试的开始就建立全部线程并立即发送访问请求, 这样一来就 ...
 - 个人经验 - Android的RelativeLayout布局的layout_height属性设置为wrap_content时的坑
			
Android的RelativeLayout布局的layout_height属性设置为wrap_content时的坑: 此坑出现的条件: 1.RelativeLayout布局的layout_heigh ...
 - 仿windows phone风格主界面
			
使用了ZAKER到最新版本,其主界面采用windows phone的风格,感觉还蛮好看的,挺喜欢的,就模仿写了一下,实现到界面截图如下: 第一版面: 第二版面: 在实现了它到九宫格菜单,还实现了背景图 ...
 - css3 javascript 实现菜单按钮特效
			
一个菜单按钮特效案例,简单的实现了动态效果. 代码效果预览地址: http://code.w3ctech.com/detail/2504 <div class="bar" i ...
 - 《Linux命令行与shell脚本编程大全》 第三章 学习笔记
			
第三章:基本的bash shell命令 bash程序使用命令行参数来修改所启动shell的类型 参数 描述 -c string 从string中读取命令并处理他们 -r 启动限制性shell,限制用户 ...
 - matlab的&和&&操作
			
A&B(1)首先判断A的逻辑值,然后判断B的值,然后进行逻辑与的计算.(2)A和B可以为矩阵(e.g. A=[1 0],B=[0 0]).A&&B(1)首先判断A的逻辑值,如果 ...
 - java 复习003
			
今天主要复习下数据结构的东西 树 自平衡二叉查找树 AVL树(高平衡树)(wiki) 特性:任何节点的两个子树的高度最大差别为一 时间复杂度:查找.插入和删除在平均和最坏情况下都是O(log n) 红 ...