模板汇总——KMP & EX-KMP
1. kmp
相当于往前求出一段字符信息,使得 这段字符信息和前缀相等。
void getnext(){
    int k = -, j = ;
    nx[] = -;
    while(j < m){
        if(k == - || b[j] == b[k]) nx[++j] = ++k;
        else k = nx[k];
    }
}
例:
#include<iostream>
using namespace std;
int nx[+], b[+], a[+];
int n, m;
void getnext(){
int k = -, j = ;
nx[] = -;
while(j < m){
if(k == - || b[j] == b[k]) nx[++j] = ++k;
else k = nx[k];
}
}
int KMP()
{
int flag = -;
for(int i = , j = ; i < n; i++){
while(j > && b[j] != a[i]) j = nx[j];
if(a[i] == b[j]) j++;
if(j == m)
{
return i - j + ;
}
}
return -;
}
int main()
{
ios::sync_with_stdio();
cin.tie();
cout.tie();
int t;
cin >> t;
while(t--){
cin >> n >> m;
for(int i = ; i < n; i++) cin >> a[i];
for(int i = ; i < m; i++) cin >> b[i];
getnext();
cout << KMP() << endl;
}
return ;
}
2. ex-kmp
相当于往后求出一段信息,使得这段信息和前缀相等。
int n, z[N];
char s[N];
void init(){
z[] = n;
int j = , k;
for(int i = ; i < n; i = k){
if(j < i) j = i;
while(j < n && S[j] == S[j-i]) j++;
z[i] = j-i;
k = i+;
while(k + z[k-i] < j)
z[k]=z[k-i],k++;
}
}
例:
T:
给出模板串A和子串B,长度分别为lenA和lenB,要求在线性时间内,对于每个A[i](1<=i<=lenA),求出A[i..lenA]与B的最长公共前缀长度。
#include<bits/stdc++.h>
using namespace std;
const int N = 2e6+; char s[N], ss[N];
int z[N];
void init(int n){
z[] = n;
int j = , k;
for(int i = ; i < n; i = k){
if(j < i) j = i;
while(j < n && s[j] == s[j-i]) j++;
z[i] = j-i;
k = i+;
while(k + z[k-i] < j)
z[k]=z[k-i],k++;
}
}
int Ac(){
scanf("%s", ss);
scanf("%s", s);
int n = strlen(s), m = strlen(ss);
s[n] = '@';
strcpy(s++n, ss);
init(n+m+);
for(int i = n+; i <= n+m; ++i){
printf("%d%c", z[i], " \n"[i==n+m]);
}
return ;
}
int main(){
Ac();
return ;
}
模板汇总——KMP & EX-KMP的更多相关文章
- kmp&扩展kmp
		
kmp: KMP的主要目的是求B是不是A的子串,以及若是,B在A中所有出现的位置 写的很详细的大佬的博客:http://www.matrix67.com/blog/archives/115 模板: / ...
 - (模板)poj3461(kmp模板题)
		
题目链接:https://vjudge.net/problem/POJ-3461 题意:给出主串和模式串,求出模式串在主串中出现的次数. 思路:kmp板子题. AC代码: #include<cs ...
 - 字符串匹配—KMP 扩展KMP Manacher
		
kuangbin字符串专题传送门--http://acm.hust.edu.cn/vjudge/contest/view.action?cid=70325#overview 算法模板: KMP: ; ...
 - hihoCoder 1015 KMP算法(kmp)
		
#1015 : KMP算法 时间限制:1000ms 单点时限:1000ms 内存限制:256MB 描写叙述 小Hi和小Ho是一对好朋友,出生在信息化社会的他们对编程产生了莫大的兴趣.他们约定好互相帮助 ...
 - KMP&拓展KMP
		
KMP算法 说明 KMP算法是一种比较高效的字符串匹配算法,可以在线性时间内求出一个串在另一个串的所有匹配位置. 解析 详解KMP 设模板串是 \(pattern\) 令 \(next[i] = ma ...
 - 【模板】NOIP模板汇总
		
图论 数据结构 数学 其他: 洛谷模板:a,b两个字符串,求b串在a串中出现的位置 #include<iostream> #include<cstdio> #include&l ...
 - KMP hihoCoder1015 KMP算法
		
人太蠢,,看了一天的KMP.. 刚開始看训练指南的,,后来才惊奇的发现原来刘汝佳写的f数组并非Next数组! 总认为和之前看过的全然不一样.. . 后来又百度了一下KMP,研究了非常久,然后用自己的逻 ...
 - kuangbin专题十六 KMP&&扩展KMP HDU2609 How many (最小字符串表示法)
		
Give you n ( n < 10000) necklaces ,the length of necklace will not large than 100,tell me How man ...
 - [kuangbin带你飞]专题十六 KMP & 扩展KMP & Manacher 题解报告
		
来刷kuangbin字符串了,字符串处理在ACM中是很重要的,一般比赛都会都1——2道有关字符串处理的题目,而且不会很难的那种,大多数时候都是用到一些KMP的性质或者找规律. 点击标题可跳转至VJ比赛 ...
 
随机推荐
- S3 介绍
			
S3 是ceph rgw的基础,在学习RGW之前,先了解S3.
 - 昏睡了8年的我带着第一个微信小程序今年醒了
			
工作8年之久的我今年算是彻底长进了,以前是知道自己的水平不咋地,但是没什么行动,理由是3年抱2娃,需要照顾孩子. 去年年底偶然一次看技术贴的时候,看到了博客园这个平台,看了很多大牛们的经历,也知道公司 ...
 - spring-boot项目的docker集成化部署(一)
			
目录 spring-boot项目的docker集成化部署 前言 基本思路与方案 基本步骤 准备源码 服务器和基础环境 结语 1. 本文总结: 2. 后期优化: spring-boot项目的docker ...
 - extjs4 表单验证自定义
			
extjs4 在验证上面支持的也特别好,他可以使用自带的格式验证,也可以自定义验证 比如:正则验证,密码重复填写对比验证,以及 调用后台方法验证,下面将验证方法统一写出以供参考 function lo ...
 - 数据结构之队列java版
			
//java由于泛型的擦除,用起来十分不方便 abstract class BaseQueue<T>{ abstract boolean enQueue(T x); abstract T ...
 - 【游记】NOIP2019前传
			
声明 我的游记是一个完整的体系,如果没有阅读过往届文章,阅读可能会受到障碍. ~~~上一篇游记的传送门~~~ 前言 比完赛后,我沉浸在胜利中长达半个月,而后才清醒过来,意识到自己需要为NOIP2019 ...
 - alluxio源码解析-netty部分(2)
			
netty简介 Netty是 一个异步事件驱动的网络应用程序框架,用于快速开发可维护的高性能协议服务器和客户端. netty作为alluxio中重要的通讯组件 在常见的客户端上传,下载中,都会有n ...
 - (二十七)c#Winform自定义控件-多输入窗体
			
前提 入行已经7,8年了,一直想做一套漂亮点的自定义控件,于是就有了本系列文章. 开源地址:https://gitee.com/kwwwvagaa/net_winform_custom_control ...
 - JS之null与undefined的区别
			
null表示尚未存在的对象 js 代码: alert(null == document.getElementById('notExistElement')); //output "true ...
 - 重学计算机组成原理(十)- "烫烫烫"乱码的由来
			
程序 = 算法 + 数据结构 对应到计算机的组成原理(硬件层面) 算法 --- 各种计算机指令 数据结构 --- 二进制数据 计算机用0/1组成的二进制,来表示所有信息 程序指令用到的机器码,是使用二 ...