数据结构之 字符串---字符串匹配(kmp算法)
串结构练习——字符串匹配
Time Limit: 1000MS Memory limit: 65536K
题目描述
输入
输出
示例输入
abc
a
123456
45
abc
ddd
示例输出
YES
YES
NO
#include <iostream>
#include <string>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <stack> using namespace std; void GET_next(string t, int next[])
{
int j, k;
j=0; k=-1;
next[0]=-1;
int len=t.size(); while(j<len )
{
if(k==-1 || t[j]==t[k] )
{
j++;
k++;
next[j]=k;
}
else
k=next[k];
}
} int KMP(string s, string t, int next[] )
{
int i, j;
i=0; j=0;
int len1=s.size();
int len2=t.size(); while(i<len1 && j<len2 )
{
if(j==-1 || s[i]==t[j] )
{
i++;
j++;
}
else
j=next[j];
}
if(j==len2 )
cout<<"YES\n";
else
cout<<"NO\n";
return 0;
} int main()
{
string s, t;
int i, j;
int len1, len2;
int next[1000]; while(cin>>s)
{
cin>>t;
len1=s.size();
len2=t.size();
GET_next(t, next);
KMP(s, t, next);
}
return 0;
}
注释化:
#include <iostream>
#include <string>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <stack> using namespace std; void GET_next(string t, int next[]) //生成next数组值
{
int j, k;
j=0; //字符串的位置下标的移动指针
k=-1;
next[0]=-1;//此处和课本不同,课本的下标从1开始,而实际是从0开始
int len=t.size(); while( j<len ) //t串长度
{
if(k==-1 || t[j]==t[k] )
{ //如果k=-1,往后移下标
j++;
k++; //k代表:t1 t2 t3...tk = t(j-k+1) t(j-k+2)...t(j-1)
//的最大值
next[j]=k; //next[当前] 被赋值
}
else
k=next[k]; //k的回退
}
int i;
/*for(i=0; i<len; i++)
{
cout<<next[i]<<" ";
}
cout<<endl; */ }
/* 例如:t串:a b a a b c a c
下标:0 1 2 3 4 5 6 7
next:-1 0 0 1 1 2 0 1
*/
int KMP(string s, string t, int next[] )
{
int i, j;
i=0; j=0;
int len1=s.size();
int len2=t.size();
//这是模式匹配过程
while(i<len1 && j<len2 )// i指向母串 j指向子串
{
if(j==-1 || s[i]==t[j] )
{ //如果j=-1,(短路运算)直接向后移,因为没有-1的下标
//如果下标合理,就比较二者指针对应的字符是否相等
i++;
j++;
}
else//如果上述两者条件不符
j=next[j]; //让子串的指针j回退,而i不会移动,节省时间
}
if(j==len2 ) //如果跑玩匹配循环 j下标已经指向len2,则说明整个
//子串的字符都已被匹配上
cout<<"YES\n";
else
cout<<"NO\n";
return 0;
} int main()
{
string s, t;
int i, j;
int len1, len2;
int next[1000];
while(cin>>s) //读入母串
{
cin>>t;//读入子串
len1=s.size(); //母串长度
// len2=t.size(); //子串长度 GET_next(s, next); //对子串t 生成next数组值
//KMP(s, t, next); //根据next数组进行kmp匹配
}
return 0;
}
数据结构之 字符串---字符串匹配(kmp算法)的更多相关文章
- 字符串匹配KMP算法详解
1. 引言 以前看过很多次KMP算法,一直觉得很有用,但都没有搞明白,一方面是网上很少有比较详细的通俗易懂的讲解,另一方面也怪自己没有沉下心来研究.最近在leetcode上又遇见字符串匹配的题目,以此 ...
- 字符串匹配--kmp算法原理整理
kmp算法原理:求出P0···Pi的最大相同前后缀长度k: 字符串匹配是计算机的基本任务之一.举例,字符串"BBC ABCDAB ABCDABCDABDE",里面是否包含另一个字符 ...
- 字符串匹配——KMP算法
关于KMP算法的分析,我觉得这两篇博客写的不错: http://www.ruanyifeng.com/blog/2013/05/Knuth–Morris–Pratt_algorithm.html ht ...
- 字符串匹配KMP算法的C语言实现
字符串匹配是计算机的基本任务之一. 举例来说,有一个字符串"BBC ABCDAB ABCDABCDABDE",我想知道,里面是否包含另一个字符串"ABCDABD" ...
- 字符串匹配KMP算法的讲解C++
转自http://blog.csdn.net/starstar1992/article/details/54913261 也可以参考http://blog.csdn.net/liu940204/art ...
- 字符串匹配KMP算法(转自阮一峰)
转自 http://www.ruanyifeng.com/blog/2013/05/Knuth%E2%80%93Morris%E2%80%93Pratt_algorithm.html 字符串匹配是计算 ...
- 【Luogu P3375】字符串匹配KMP算法模板
Luogu P3375 模式串:即题目中的S2所代表的意义 文本串:即题目中的S1所代表的意义 对于字符串匹配,有一种很显然的朴素算法:在S1中枚举起点一位一位匹配,失配之后起点往后移动一位,从头开始 ...
- Java数据结构之字符串模式匹配算法---KMP算法
本文主要的思路都是参考http://kb.cnblogs.com/page/176818/ 如有冒犯请告知,多谢. 一.KMP算法 KMP算法可以在O(n+m)的时间数量级上完成串的模式匹配操作,其基 ...
- 字符串匹配KMP算法
1. 字符串匹配的KMP算法 2. KMP算法详解 3. 从头到尾彻底理解KMP
随机推荐
- Spring Boot中实现异步调用之@Async
一.什么是异步调用 “异步调用”对应的是“同步调用”,同步调用指程序按照定义顺序依次执行,每一行程序都必须等待上一行程序执行完成之后才能执行:异步调用指程序在顺序执行时,不等待异步调用 的语句返回结果 ...
- OAuth相关备注
引用大神的资料,备注一下 http://www.cnblogs.com/dudu/tag/OAuth/
- 跳转到指定页面popToViewController用法
有人问popToViewController的用法 就写了下了 希望能帮到有需要的人 [self.navigationController popToViewController:[self.navi ...
- 【spring data jpa】启动报错:nested exception is java.util.NoSuchElementException
spring boot项目中 使用spring data jpa 启动报错: org.springframework.beans.factory.UnsatisfiedDependencyExcept ...
- iOS -- xxxViewController进行pop时直接crash进main.m,EXC_BAD_ACCESS(code=1,address=0x20)
今天在调试程序时,遇到了奇怪的错误.我从主页跳进(push)一个ViewController时一切正常,但是返回主页(pop)时却crash了,直接跳进了main.m(EXC_BAD_ACCESS(c ...
- 每天进步一点点—SQL优化
一. SQL优化 1. 通过show status 命令了解各种SQL的运行频率 mysql>show status like 'Com_%'; +----------- ...
- 【Lintcode】二叉树的最大深度 - 比较简单,用递归比较好,不递归也能做,比较麻烦
给定一个二叉树,找出其最大深度. 二叉树的深度为根节点到最远叶子节点的距离. 您在真实的面试中是否遇到过这个题? Yes 样例 给出一棵如下的二叉树: 1 / \ 2 3 / \ 4 5 这个二叉树的 ...
- linux下脚本监控网络流量
linux下脚本监控网络流量 学习了:https://blog.csdn.net/chenghuikai/article/details/48437479 学习了:http://www.jb51.ne ...
- mysql手动停止无响应查询方法
http://www.chenweionline.cn/archives/61.htm
- mysql (8.0 或以下)数据 卸载, 安装, 创建用户, 赋权
卸载 安装 创建用户wmxl create user 'wmxl'@'202.115.253.71' identified by '你的密码' 如果是mysql8.0,再输入以下 ALTER USER ...