UVAlive 3026 KMP 最小循环节
KMP算法:
一:next数组:next[i]就是前面长度为i的字符串前缀和后缀相等的最大长度,也即索引为i的字符失配时的前缀函数。
二:KMP模板
- /*
- pku3461(Oulipo), hdu1711(Number Sequence)
- 这个模板 字符串是从0开始的
- Next数组是从1开始的
- */
- #include <iostream>
- #include <cstring>
- using namespace std;
- const int maxn = ;
- int _next[maxn];
- char S[maxn], T[maxn];
- int slen, tlen;
- void getNext()
- {
- int j, k;
- j = ; k = -; _next[] = -;
- while(j < tlen)
- if(k == - || T[j] == T[k])
- _next[++j] = ++k;
- else
- k = _next[k];
- }
- /*
- }
- 返回模式串T在主串S中首次出现的位置
- 返回的位置是从0开始的。
- */
- int KMP_Index()
- {
- int i = , j = ;
- getNext();
- while(i < slen && j < tlen)
- {
- if(j == - || S[i] == T[j])
- {
- i++; j++;
- }
- else
- j = _next[j];
- }
- if(j == tlen)
- return i - tlen;
- else
- return -;
- }
- /*
- 返回模式串在主串S中出现的次数
- */
- int KMP_Count()
- {
- int ans = ;
- int i, j = ;
- if(slen == && tlen == )
- {
- if(S[] == T[])
- return ;
- else
- return ;
- }
- getNext();
- for(i = ; i < slen; i++)
- {
- while(j > && S[i] != T[j])
- j = _next[j];
- if(S[i] == T[j])
- j++;
- if(j == tlen)
- {
- ans++;
- j = _next[j];
- }
- }
- return ans;
- }
- int main()
- {
- int TT;
- int i, cc;
- cin>>TT;
- while(TT--)
- {
- cin>>S>>T;
- slen = strlen(S);
- tlen = strlen(T);
- cout<<"模式串T在主串S中首次出现的位置是: "<<KMP_Index()<<endl;
- cout<<"模式串T在主串S中出现的次数为: "<<KMP_Count()<<endl;
- }
- return ;
- }
三:KMP最小循环节、循环周期:
定理:假设S的长度为len,则S存在最小循环节,循环节的长度L为len-next[len],子串为S[0…len-next[len]-1]。
(1)如果len可以被len - next[len]整除,则表明字符串S可以完全由循环节循环组成,循环周期T=len/L。
(2)如果不能,说明还需要再添加几个字母才能补全。需要补的个数是循环个数L-len%L=L-(len-L)%L=L-next[len]%L,L=len-next[len]。
学习博客 https://www.cnblogs.com/chenxiwenruo/p/3546457.html
https://www.cnblogs.com/c-cloud/p/3224788.html
循环节例题
题目链接 https://vjudge.net/problem/UVALive-3026
解析 每个前缀的最小循环节 KMP跑一边判断能不能整除就可以了
AC代码
- #include <bits/stdc++.h>
- #define pb push_back
- #define mp make_pair
- #define F first
- #define S second
- #define all(a) (a).begin(), (a).end()
- #define fillchar(a, x) memset(a, x, sizeof(a))
- #define huan printf("\n");
- using namespace std;
- typedef long long ll;
- const int maxn=1e6+,inf=0x3f3f3f3f;
- const ll mod=1e9+;
- char p[maxn];
- int f[maxn];
- int main()
- {
- int n,kase=;
- while(scanf("%d",&n)==&&n)
- {
- scanf("%s",p);
- f[]=,f[]=;
- for(int i=;i<n;i++)
- {
- int j=f[i];
- while(j&&p[i]!=p[j]) j=f[j];
- f[i+]=(p[i]==p[j]?j+:);
- }
- printf("Test case #%d\n", ++kase);
- for(int i=;i<=n;i++)
- {
- if(f[i]>&&i%(i-f[i])==)
- printf("%d %d\n",i,i/(i-f[i]));
- }
- huan;
- }
- }
UVAlive 3026 KMP 最小循环节的更多相关文章
- Cyclic Nacklace hdu3746 kmp 最小循环节
题意:给出一段字符串 求最少在最右边补上多少个字符使得形成循环串(单个字符不是循环串) 自己乱搞居然搞出来了... 想法是: 如果nex[len]为0 那么答案显然是补len 否则 答案为循环 ...
- HDU1358 Period —— KMP 最小循环节
题目链接:https://vjudge.net/problem/HDU-1358 Period Time Limit: 2000/1000 MS (Java/Others) Memory Lim ...
- Common Divisors CodeForces - 182D || kmp最小循环节
Common Divisors CodeForces - 182D 思路:用kmp求next数组的方法求出两个字符串的最小循环节长度(http://blog.csdn.net/acraz/articl ...
- HDU - 4333 Revolving Digits(拓展kmp+最小循环节)
1.给一个数字字符串s,可以把它的最后一个字符放到最前面变为另一个数字,直到又变为原来的s.求这个过程中比原来的数字小的.相等的.大的数字各有多少. 例如:字符串123,变换过程:123 -> ...
- 【KMP+最小循环节】F. Cyclic Nacklace
https://www.bnuoj.com/v3/contest_show.php?cid=9147#problem/F [题意] 给定一个字符串,问在字符串后最少添加多少个字母,得到的新字符串能是前 ...
- [poj 2185] Milking Grid 解题报告(KMP+最小循环节)
题目链接:http://poj.org/problem?id=2185 题目: Description Every morning when they are milked, the Farmer J ...
- hdu3746(kmp最小循环节)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3746 题意:问在一个字符串末尾加上多少个字符能使得这的字符串首尾相连后能够循环 题解:就是利用next ...
- HDU 6740 kmp最小循环节
题意:给一个无线循环小数的前几位,给n,m 选择其中一种出现在前几位的循环节方式(a个数),循环节的长度b 使得n*a-m*b最大 样例: 2 1 12.1212 输出 6 选择2,2*1-1*1=1 ...
- hdu 3746 Cyclic Nacklace(kmp最小循环节)
Problem Description CC always becomes very depressed at the end of this month, he has checked his cr ...
随机推荐
- IOS问题
#import "EXFifthViewController.h" @interface EXFifthViewController () @end @implementation ...
- ios项目中引用其他开源项目
1. 将开源项目的.xcodeproj拖入项目frameworks 2. Build Phases下 Links Binary With Libraries 引入.a文件.Target Depende ...
- webuploader上传工具
http://fex.baidu.com/webuploader/getting-started.html#显示用户选择 Html部分 首先准备dom结构,包含存放文件信息的容器.选择按钮和上传按钮三 ...
- [Python筆記] 將 Pandas 的 Dataframe 寫入 Sqlite3
使用 pandas.io 寫入 Sqlite import sqlite3 as lite from pandas.io import sql import pandas as pd 依照 if_ex ...
- SEO 第十章
SEO第十章 本次课目标: 1. 站外优化方案计划 2. 常见的SEO作弊手段(黑帽) 3. 百度站长平台的使用 4. 网站流量提升和转化率提升 一.站外优化方案计划 友情链接 权重相当.行业 ...
- hdu5792 World is Exploding(多校第五场)树状数组求逆序对 离散化
题目地址:http://acm.hdu.edu.cn/showproblem.php?pid=5792 题目描述:给你n个值,每个值用A[i]表示,然后问你能否找到多少组(a,b,c,d)四个编号,四 ...
- springBoot + KISSO实现单点登录
1:创建一个maven项目 kisso,然后再创建二个子项目都是springboot 2:二个boot项目的pom.xml都是一样的 就这三个依赖,3:接下来就是码代码了,首先在(在我这里)sprin ...
- iOS代理模式
iOS代理模式的简单理解:当一个对象无法直接获取到另一个对象的指针,又希望对那个变量进行一些操作时,可以使用代理模式. 代理主要由三部分组成: (1)协议:用来指定代理双方可以做什么,必须做什么. ( ...
- QT_7_资源文件_对话框_QMessageBox_界面布局_常用控件
资源文件 1.1. 将资源导入到项目下 1.2. 添加文件—>Qt -->Qt Resource File 1.3. 起名称 res ,生成res.qrc文件 1.4. 右键 open i ...
- [模板] LIS
树状数组优化LIS到nlogn,网上找了好多,感觉讲得都不是很明白,正好自己复习整理一下. 基本的DP方程 f[i]=max(f[i],f[j]+1) (j<i且a[j]<a[i]) 定义 ...