Power Strings(kmp妙解)
Power Strings
Time Limit : 6000/3000ms (Java/Other) Memory Limit : 131072/65536K (Java/Other)
Total Submission(s) : 29 Accepted Submission(s) : 14
描述:
对于数组s[0~n-1],计算next[0~n](多计算一位)。
考虑next[n],假设t=n-next[n],如果n%t==0,则t就是问题的解,否则解为1。
这样考虑:
比如字符串"abababab",
a b a b a b a b *
next -1 0 1 2 3 4 5 6 7
考虑这样的模式匹配,将"abababab#"当做主串,"abababab*"当做模式串,于是进行匹配到n(n=8)时,出现了不匹配:
主串 abababab#
模式串 abababab*
于是模式串需要回溯到next[*]=7,这之前的主串和模式串对应相等,于是需要模式串向右滚动的位移是d=n-next[n]=2,即:
123456789
主串 abababab#
模式串 abababab*
于是可以看出,s[0~1]=s[3~4]=s[5~6]=s[7~8]。
所以位移d=n-next[n]可以看作是构成字符串s的字串(如果n%d==0,存在这样的构成),相应的重复次数也就是n/d。
n-next[n]也就是当前最小匹配的字串长度。。。。。此处的next数组相当于代码中的p数组......
代码:
#include<stdio.h>
#include<string.h>
const int MAXN=;
int p[MAXN];
char s[MAXN];
int n,len;
void getp(){
int i=,j=-;
p[]=-;
while(i<len){
if(j==-||s[j]==s[i]){
i++;j++;
p[i]=j;
}
else j=p[j];
}
}
int main(){int answer;
while(scanf("%s",s),strcmp(s,".")){
memset(p,,sizeof(p));
len=strlen(s);
getp();
/*for(int i=0;i<=len;i++)printf("%d ",p[i]);
puts("");*/
answer=;
if(len%(len-p[len])==)answer=len/(len-p[len]);
printf("%d\n",answer);
}
return ;
}
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
using namespace std;
typedef long long LL;
#define mem(x,y) memset(x,y,sizeof(x))
#define SI(x) scanf("%d",&x)
#define PI(x) printf("%d",x)
const int INF=0x3f3f3f3f;
const int MAXN=1000010;
int p[MAXN]; void getp(char* s){
int len=strlen(s);
int i=0,j=-1;
p[0]=-1;
while(i<len){
if(j==-1||s[i]==s[j]){
i++;j++;
p[i]=j;
}
else j=p[j];
}
} int main(){
char s[MAXN];
while(~scanf("%s",s),strcmp(s,".")){
getp(s);
int len=strlen(s);
if(len==0){
puts("0");continue;
}
if(p[len]!=-1&&len%(len-p[len])==0){
printf("%d\n",len/(len-p[len]));
}
else puts("1");
}
return 0;
}
下面是修正过的:
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
typedef long long LL;
const int MAXN = ;
char s[MAXN];
int next[MAXN];
void getp(){
int i = , j = -;
next[i] = j;
while(s[i]){
if(j == - || s[i] == s[j]){
i++;j++;
next[i] = j;
if(s[i] == s[j])
next[i] = next[j];
}
else
j = next[j];
}
} int main(){
while(scanf("%s", s), s[] != '.'){
getp();
int len = strlen(s);
// for(int i = 0; i <= len; i++){
// printf("%d ", next[i]);}puts("");
if(len % (len - next[len]) == && len / (len - next[len]) > ){
printf("%d\n", len / (len - next[len]));
}
else puts("");
}
return ;
}
java写法:
import java.util.Scanner;
public class kmp{
public static class newkmp extends kmpmod{
public void work(char[] str){
getp(str);
//System.out.print(p[len]);
if(len % (len - p[len]) == )
System.out.println(len/(len - p[len]));
else
System.out.println();
}
}
public static char[] str = new char[];
public static void main(String[] argv){
Scanner cin = new Scanner(System.in);
newkmp kmp1 = new newkmp();
while(cin.hasNext()){
str = cin.next().toCharArray();
if(str.length == && str[] == '.')
break;
//System.out.print(str);
kmp1.work(str);
}
}
}
abstract class kmpmod{
protected int p[] = new int[];
protected int len;
public void getp(char[] str){
for(int i = ; i < p.length; i++){
p[i] = ;
}
len = str.length;
int i = , j = -;
p[] = -;
while (i < str.length) {
if(j == - || str[i] == str[j]){
i++; j++;
p[i] = j;
}
else{
j = p[j];
}
}
}
public abstract void work(char[] str);
}
Power Strings(kmp妙解)的更多相关文章
- POJ 2406 Power Strings (KMP)
Power Strings Time Limit: 3000MSMemory Limit: 65536K Total Submissions: 29663Accepted: 12387 Descrip ...
- poj 2406 Power Strings kmp算法
点击打开链接 Power Strings Time Limit: 3000MS Memory Limit: 65536K Total Submissions: 27368 Accepted: ...
- UVA - 10298 Power Strings (KMP求字符串循环节)
Description Problem D: Power Strings Given two strings a and b we define a*b to be their concatenati ...
- UVA10298 Power Strings [KMP]
题目传送门 Power Strings 格式难调,题面就不放了. 一句话题意,求给定的若干字符串的最短循环节循环次数. 输入样例#1: abcd aaaa ababab . 输出样例#1: 1 4 3 ...
- POJ2406 Power Strings —— KMP or 后缀数组 最小循环节
题目链接:https://vjudge.net/problem/POJ-2406 Power Strings Time Limit: 3000MS Memory Limit: 65536K Tot ...
- poj2406 Power Strings (kmp 求最小循环字串)
Power Strings Time Limit: 3000MS Memory Limit: 65536K Total Submissions: 47748 Accepted: 19902 ...
- poj 2406 Power Strings (kmp 中 next 数组的应用||后缀数组)
http://poj.org/problem?id=2406 Power Strings Time Limit: 3000MS Memory Limit: 65536K Total Submiss ...
- poj 2406 Power Strings(KMP变形)
Power Strings Time Limit: 3000MS Memory Limit: 65536K Total Submissions: 28102 Accepted: 11755 D ...
- POJ2406 Power Strings KMP算法
给你一个串s,如果能找到一个子串a,连接n次变成它,就把这个串称为power string,即a^n=s,求最大的n. 用KMP来想,如果存在的话,那么我每次f[i]的时候退的步数应该是一样多的 譬 ...
随机推荐
- hdu1556 Color the ball
#include <iostream> #include <cstdio> #include <cstring> #include <algorithm> ...
- 文件MD5
package mainimport ( "crypto/md5" "fmt" // "github.com/astaxie/bee ...
- 不可或缺的企业OA面临问题,以及解决建议 软件定制开发 森普演示平台
---恢复内容开始--- 随着信息时代的来临,企业管理也相应的信息化,各种管理软件相继而出,各行各业的信息化有过成功,也有过失败(注:是以该项目是否达到用户的预期目标而言).据统计在信息化失败的案例中 ...
- A Bug's Life
#include<stdio.h> #include<string.h> ],num[]; int find(int x){ int r=x; while(r!=bug[r]) ...
- c保存lua函数
使用下面方式可保存lua任何值,目前只实现fucntion的保存,且无参数.如果需要实现参数,可自己扩展: 可实现下面方式: CFun( lua_fun ) -- okCFun( function() ...
- SQL SERVER 2005 错误:18456
安装好SQL SERVER 2005之后,Windows身份验证无法登陆,出现18456错误.而sql server 身份验证可以用sa用户登陆. 解决办法: 用sa用户登陆,执行SQL 语句: CR ...
- Angular之filter学习
过滤器(filter)正如其名,作用就是接收一个输入,通过某个规则进行处理,然后返回处理后的结果.主要用在数据的格式化上,例如获取一个数组中的子集,对数组中的元素进行排序等.ng内置了一些过滤器,它们 ...
- C#中操作刚导出的Excel,设置其为自动调整列宽
[问题] 用C#导出数据为excel,但是导出的数据中,不是自动调整列宽的: 希望变成这样的: [解决过程] 1.参考: 在C#里对excel文件的列宽进行操作 去试试: //auto adjust ...
- tomcat https jks 沃通免费证书安装 解决方案
网上百度了一天什么没百度到,最后谷歌到了一篇文章启发之下解决之. 代理谷歌网站推荐一个,可以直接上谷歌: https://www.yundou.info ----------------------- ...
- Android 轮询之 Service + AlarmManager+Thread (转)
android中涉及到将服务器中数据变化信息通知用户一般有两种办法,推送和轮询. 消息推送是服务端主动发消息给客户端,因为第一时间知道数据发生变化的是服务器自己,所以推送的优势是实时性高.但服务器主动 ...