KMP算法(查找子序列)
KMP类似暴力,但是不会和暴力完全一样,回溯到起点。
简单的说 假如 模板链字符串是: abcabcabcabd 寻找abcabd 在模板链出现的次数,并且输出该次数。
完全暴力过程:
假设 a【】为模板链,b【】为要查找的子序列。
先取b【】的首一直对应,然后a【】,b【】同时移动,当a【】,b【】不匹配的时候,b【】回到起点,a【】向后移动单位1。 这点很容易想到,我写出来是为了方便和后面的KMP算法作比较。
KMP过程:
假设仍然如上。
这个我们先要对b【】进行处理,假设做一个int的数组 next【】
b【】 a b c a b d
next【】 -1 0 0 0 1 2
匹配过程:
a【】 a b c a b c a b d >>>>>>>>>假设 在a中,查找b出现的次数,区间不交叉
简单说吧
前面和暴力相同
暴力得到结果为:a b c a b //此处还有d没匹配,下一步就是KMP的用处了
不同之处在于
a b c a b d(d处不对应)
下一次匹配对应的是
a b c a b d
(移动的位置跟next相同,d对应的next的值为2,所以b【】移动1+2的位置)
入门题: hdu 2087 点击打开链接
ac代码:
#include<cstdio>
#include<cstring>
char a[1010],b[1010];
int next[1010];
int lena,lenb;
void getnext()               //做的第一步是获得next【】的值
{
int i=0,k=-1;
next[0]=-1;
while (i<lenb)
{
if (k==-1||b[i]==b[k])
{
i++;
k++;
next[i]=k;
}
else k=next[k];
}
}
int KMP()
{
getnext();
int i=0,j=0,cnt=0;
while (i<lena)
{
if (j==-1||a[i]==b[j])
{
i++;j++;
}
else j=next[j];
if (j==lenb)
{
cnt++;
j=0;
}	
}	
return cnt;
}
int main()
{
while(scanf("%s",a)!=EOF)
{
if (*a=='#')
break;
scanf("%s",b);
lena=strlen(a);
lenb=strlen(b);
printf ("%d\n",KMP());
}
return 0;
}
KMP算法(查找子序列)的更多相关文章
- 回朔法/KMP算法-查找字符串
		
回朔法:在字符串查找的时候最容易想到的是暴力查找,也就是回朔法.其思路是将要寻找的串的每个字符取出,然后按顺序在源串中查找,如果找到则返回true,否则源串索引向后移动一位,再重复查找,直到找到返回t ...
 - 数据结构与算法--KMP算法查找子字符串
		
数据结构与算法--KMP算法查找子字符串 部分内容和图片来自这三篇文章: 这篇文章.这篇文章.还有这篇他们写得非常棒.结合他们的解释和自己的理解,完成了本文. 上一节介绍了暴力法查找子字符串,同时也发 ...
 - KMP算法查找字符串
		
假设长字符串为t,短字符串为p.为了进行KMP匹配,首先需要计算字符串p的next数组,后面实现了计算该数组的函数void KmpGenNext(char* p, int* next).对于”abca ...
 - 字符串匹配的KMP算法详解及C#实现
		
字符串匹配是计算机的基本任务之一. 举例来说,有一个字符串"BBC ABCDAB ABCDABCDABDE",我想知道,里面是否包含另一个字符串"ABCDABD" ...
 - POJ 3461 Oulipo(字符串匹配,KMP算法)
		
题意:给出几组数据,每组有字符串W和T,问你W在T中出现几次. 思路:字符串长度很大,用KMP算法. 一开始写的是:调用KMP算法查找W在T中是否匹配,若匹配,则个数+1.则接下来T的索引移动相应的距 ...
 - 完全掌握KMP算法思想
		
文档下载页面http://download.csdn.net/detail/yedeqixian/4209500 80页在讲KMP算法的开始先举了个例子,让我们对KMP的基本思想有了最初的认 ...
 - KMP算法模式匹配
		
转载请注明出处 http://blog.csdn.net/pony_maggie/article/details/37832707 作者:小马 在一个长串中查找一个子串是较经常使用的操作.各种信息检索 ...
 - 串匹配问题 (KMP算法) 详解
		
串这个概念对于我们学到现在的水平来说应该是经历颇丰了,因为在C语言中我们所用到的"串"知识是在字符串那里,有了这个概念,我们再去学习串就相对而言轻松多了. 那么,现在来介绍一下字符 ...
 - 查找字符串的 KMP 算法
		
查找字符串是我们平常编程过程中经常遇到的,现在介绍一种查找字符串算法,增加程序的执行速度. 通常我们是这么写的: /* content: search a string in a othor stri ...
 
随机推荐
- 常用的shell语句 【awk】去重,排列
			
目的:从日志access.log中,筛选出IP来,并统计每个IP出现的次数,然后显示出来. 因为:awk = 扒IP shot = 排序 uniq = 去重 所以:awk '{print $1} ...
 - React总结和遇到的坑
			
一.react项目 前端react后端node:https://github.com/GainLoss/react-juejin 前端react后端Pyton:https://github.com/G ...
 - Jmeter入门2  http请求—简单的get请求
			
发送一个简单的get http请求 1 启动Jmeter,在测试计划上点击鼠标右键>添加>Threads(Users)>线程组 2 线程组界面.可设置线程数,几秒启动所有线程,循环次 ...
 - typescript 添加基础类型的扩展方法
			
以时间转换为案例: //声明接口,也是在声明date这个基础类型要定义一个format的扩展方法,不写接口声明会报错 interface Date { Format(fmt:string):strin ...
 - 【转】onConfigurationChanged
			
http://blog.csdn.net/xiaodongvtion/article/details/679938 转载自该文章. 注意:onConfigurationChanged事件并不是只有屏幕 ...
 - (第五场)G max 【数论】
			
题目链接:https://www.nowcoder.com/acm/contest/143/G 题目描述 Give two positive integer c, n. You need to fin ...
 - 【洛谷P3205】[HNOI2010]CHORUS 合唱队
			
合唱队 区间DP f[l][r][0/1]表示生成目标序列中的区间[l,r],最后一个数是a[l]/a[r] 的方案数 边界: f[i][i][0]=1 转移: f[l][r][0]=(a[l]< ...
 - CodeForces - 600B  Queries about less or equal elements (二分查找 利用stl)
			
传送门: http://codeforces.com/problemset/problem/600/B Queries about less or equal elements time limit ...
 - JS JavaScript中的this
			
this是JavaScript语言中的一个关键字 它是函数运行时,在函数体内部自动生成的一个对象,只能在函数体内部使用. function test() { this.x = 1; } 上面代码中,函 ...
 - BP神经网络—java实现(转载)
			
神经网络的结构 神经网络的网络结构由输入层,隐含层,输出层组成.隐含层的个数+输出层的个数=神经网络的层数,也就是说神经网络的层数不包括输入层.下面是一个三层的神经网络,包含了两层隐含层,一个输出层. ...