POJ 1961 Period KMP算法之next数组的应用
题意:给一个长度为n的字符串,如果它长度为l(2 <= l <= n)的前缀部分是由一些相同的字符串相接而成,输出前缀的长度l和长度为l时字符串重复的最大次数。
例如字符串为: aaaba。对于长度为2的前缀"aa"来说, “aa”最多由两个‘a’连接而成。对于长度为3的前缀"aaa"来说,“aaa”最多由三个'a'连接而成。
思路:该问题恰好用到了next数组的特性。
在kmp算法中,当字符串匹配失败时,next数组给出模式串接下来要匹配的位置。它的目的在于尽可能得利用模式串的特征少往回退。
假如匹配失败的位置为j,则对于S[0]S[1]S[2]...S[j-1]都是匹配成功的。现如果有一个最大的k,且满足S[0]S[1]S[2]...S[k-1]与S[j-k]S[j-k+1]...S[j-1]相同,则可知接下来应当将模式串的S[k]与主串匹配,即next[j] = k。
考虑该题情况,如果长度为l的前缀是由字符串重复构成的,则next[l] != 0(由上面k的定义可知),且此时构成前缀的重复子串的最小长度为l - next[l],l % (l - next[l]) = 0,最大重复次数为l / (l - next[l])。
#include<stdio.h>
#define maxn 1000010
char str[maxn];
int next[maxn], len;
void get_next()
{
next[] = -;
int i = ;
int j = -;
while (i < len)
{
if (j == - || str[i] == str[j])
{
i++; j++;
next[i] = j;
}
else j = next[j];
}
}
int main()
{
int cas = ;
while (scanf("%d", &len) && len)
{
scanf("%s", str);
get_next();
printf("Test case #%d\n", cas++);
for (int i = ; i <= len; i++)
if (next[i] && i % (i - next[i]) == )
printf("%d %d\n", i, i / (i - next[i]));
printf("\n");
}
return ;
}
POJ 1961 Period KMP算法之next数组的应用的更多相关文章
- POJ 1961 Period   KMP算法next数组的应用
		
题目: http://poj.org/problem?id=1961 很好的题,但是不容易理解. 因为当kmp失配时,i = next[i],所以错位部分就是i - next[i],当s[0]...s ...
 - POJ 1961 Period( KMP )*
		
Period Time Limit: 3000MSMemory Limit: 30000K Total Submissions: 12089Accepted: 5656 Description For ...
 - poj 2406:Power Strings(KMP算法,next[]数组的理解)
		
Power Strings Time Limit: 3000MS Memory Limit: 65536K Total Submissions: 30069 Accepted: 12553 D ...
 - hdu 1358:Period(KMP算法,next[]数组的使用)
		
Period Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Subm ...
 - KMP POJ 1961 Period
		
题目传送门 /* 题意:求一个串重复出现(>1)的位置 KMP:这简直和POJ_2406没啥区别 */ /******************************************** ...
 - KMP算法的next[]数组通俗解释
		
原文:https://blog.csdn.net/yearn520/article/details/6729426 我们在一个母字符串中查找一个子字符串有很多方法.KMP是一种最常见的改进算法,它可以 ...
 - LA 3026 && POJ 1961 Period (KMP算法)
		
题意:给定一个长度为n字符串s,求它每个前缀的最短循环节.也就是对于每个i(2<=i<=n),求一个最大整数k>1(如果存在),使得s的前i个字符组成的前缀是某个字符串重复得k次得到 ...
 - KMP——POJ-3461   Oulipo &&    POJ-2752  Seek the Name, Seek the Fame   &&   POJ-2406  Power Strings  && POJ—1961  Period
		
首先先讲一下KMP算法作用: KMP就是来求在给出的一串字符(我们把它放在str字符数组里面)中求另外一个比str数组短的字符数组(我们叫它为ptr)在str中的出现位置或者是次数 这个出现的次数是可 ...
 - POJ 2406 Power Strings KMP算法之next数组的应用
		
题意:给一个字符串,求该串最多由多少个相同的子串相接而成. 思路:只要做过poj 1961之后,这道题就很简单了.poj 1961 详细题解传送门. 假设字符串的长度为len,如果 len % (le ...
 
随机推荐
- 获取获取docker的文件
			
1.docke实例内mysql 导出文件 mysql -h yourhost -P yourport -u user -p dbname -e "select * from employee ...
 - 手机端sticker布局,底部按钮在屏幕底部
			
<template> <div class="product-detail-container"> <div class="detail&q ...
 - day18 js 正则,UI框架,Django helloworld 以及完整工作流程
			
JS正则: text 判断字符串是否符合规定的正则表达式 exec 获取匹配的数据 默认情况下: 只要能匹配到就返回true 否则返回false 只匹配数字: 所以J ...
 - Python框架之Django学习笔记(十六)
			
Django框架之表单(续) 今天简直无力吐槽了,去了香山,结果和网上看到的简直是天壤之别啊,说好的香山的枫树呢?说好的香山的红叶呢?说好的漫山遍野一片红呢?本以为在山上,一口气爬上去,沿路基本都是翠 ...
 - 【Longest Substring Without Repeating Characters】cpp
			
题目: Given a string, find the length of the longest substring without repeating characters. For examp ...
 - Oracle 学习笔记(Windows 环境下安装 + PL/SQL)
			
Oracle 安装.PL/SQL 配置使用 前言:因更换机械硬盘为 SSD 固态硬盘装了新 Windows 7 系统,需要重新搭建开发环境,把 Oracle 安装过程和 PL/SQL 配置使用做下笔 ...
 - 启用hyper后无法打开vmware
			
十万火急,想办法先让虚拟机能够打开,毕竟经常用. 网上看了无数教程都是让在控制面板中关闭hyper-v,然而并没有用. 找了好久说是不能那样关闭,得用指令.管理员运行powershell,输入下列指令 ...
 - Github问题An error occurred trying to download
			
Github for windows安装过程出现了这样的问题An error occurred trying to download 'http://github-windows.s3.amazona ...
 - Kafka 配置参数
			
Broker Configs Property Default Description broker.id 每个broker都可以用一个唯一的非负整数id进行标识:这个id可以作为broker的 ...
 - 【LeetCode】Longest Substring Without Repeating Characters(无重复字符的最长子串)
			
这道题是LeetCode里的第3道题. 题目描述: 给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度. 示例 1: 输入: "abcabcbb" 输出: 3 解释: ...