字符串的模式匹配算法——KMP模式匹配算法
朴素的模式匹配算法(C++)
朴素的模式匹配算法,暴力,容易理解
#include<iostream>
using namespace std;
int main()
{
string mainStr, str;
cin >> mainStr >> str;
int i, j, pos = -1, count = 0;
for(i = 0; i < mainStr.length(); i++)
{
for(j = 0; j < str.length(); j++, i++)
{
if(mainStr[i] != str[j])
{
break;
}
if(j == str.length() - 1)
{
if(count == 0)
{
pos = i - j; //记录第一个与str相等的字符串在主串mainStr中的第一个字母的下标
}
count++; //记录与str相等的字符串的数量
}
}
i = i - j; //对i值(主串指针)进行回溯操作
}
cout << "pos=" << pos << ",count=" << count << endl;
return 0;
}
KMP模式匹配算法(C++)
KMP模式匹配算法相比较朴素的模式匹配算法,减少了主串指针回溯的操作
#include<iostream>
using namespace std;
int main()
{
string mainStr, str;
cin >> mainStr >> str;
int i, j, pos = -1, count = 0;
int next[256];
//计算next数组的数值
i = 0;
j = -1;
next[0] = -1;
while(i < str.length())
{
if(j == -1 || str[i] == str[j])
{
i++;
j++;
next[i] = j;
}
else
{
j = next[j];
}
}
//查找子串的位置和数量
i = 0;
j = 0;
while(i < mainStr.length())
{
if(mainStr[i] != str[j])
{
j = next[j];
}
else
{
if(j == str.length() - 1)
{
if(count == 0)
{
pos = i - j; //记录子串第一次的第一个字母出现在主串中的位置
}
count++; //记录在主串中含有子串的数量
}
}
i++;
j++;
}
cout << "pos=" << pos << ",count=" << count << endl;
return 0;
}
KMP模式匹配算法改进(C++)
改进操作在于计算next数组数值的时候考虑了特殊情况 —— 子串形如abcabcabx
#include<iostream>
using namespace std;
int main()
{
string mainStr, str;
cin >> mainStr >> str;
int i, j, pos = -1, count = 0;
int next[256];
//计算next数组的数值
i = 0;
j = -1;
next[0] = -1;
while(i < str.length())
{
if(j == -1 || str[i] == str[j])
{
i++;
j++;
if(str[j] == str[i])
{
next[i] = next[j];
}
else
{
next[i] = j;
}
}
else
{
j = next[j];
}
}
//查找子串的位置和数量
i = 0;
j = 0;
while(i < mainStr.length())
{
if(mainStr[i] != str[j])
{
j = next[j];
}
else
{
if(j == str.length() - 1)
{
if(count == 0)
{
pos = i - j; //记录子串第一次的第一个字母出现在主串中的位置
}
count++; //记录在主串中含有子串的数量
}
}
i++;
j++;
}
cout << "pos=" << pos << ",count=" << count << endl;
return 0;
}
字符串的模式匹配算法——KMP模式匹配算法的更多相关文章
- C++编程练习(7)----“KMP模式匹配算法“字符串匹配
子串在主串中的定位操作通常称做串的模式匹配. KMP模式匹配算法实现: /* Index_KMP.h头文件 */ #include<string> #include<sstream& ...
- 数据结构——串的朴素模式和KMP匹配算法
一.朴素模式 假设我们要从主串S="goodgoogle"中找到子串T="google"的位置,步骤如下: i表示主串的当前位置下标,j表示子串的当前位置下标, ...
- [从今天开始修炼数据结构]串、KMP模式匹配算法
[从今天开始修炼数据结构]基本概念 [从今天开始修炼数据结构]线性表及其实现以及实现有Itertor的ArrayList和LinkedList [从今天开始修炼数据结构]栈.斐波那契数列.逆波兰四则运 ...
- 串、KMP模式匹配算法
串是由0个或者多个字符组成的有限序列,又名叫字符串. 串的比较: 串的比较是通过组成串的字符之间的编码来进行的,而字符的编码指的是字符在对应字符集中的序号. 计算机中常用的ASCII编码,由8位二进制 ...
- 《数据结构》之串的模式匹配算法——KMP算法
//串的模式匹配算法 //KMP算法,时间复杂度为O(n+m) #include <iostream> #include <string> #include <cstri ...
- KMP模式匹配算法
KMP模式匹配算法 相信很多人对于这个还有点不了解,或者说是不懂,下面,通过一道题,来解决软考中的这个问题! 正题: aaabaaa,其next函数值为多少? 对于这个问题,我们应该怎么做呢? 1.整 ...
- 线性表-串:KMP模式匹配算法
一.简单模式匹配算法(略,逐字符比较即可) 二.KMP模式匹配算法 next数组:j为字符序号,从1开始. (1)当j=1时,next=0: (2)当存在前缀=后缀情况,next=相同字符数+1: ( ...
- 详细解读KMP模式匹配算法
转载请注明出处:http://blog.csdn.net/fightlei/article/details/52712461 首先我们需要了解什么是模式匹配? 子串定位运算又称为模式匹配(Patter ...
- 字符串的朴素模式和KMP模式匹配
先复习一下字符串指针: #include <iostream> #include <string.h> using namespace std; int main() { ch ...
随机推荐
- Consistent 与 Mirrored 视角
Consistent 与 Mirrored 视角 在进行分布式训练时,OneFlow 框架提供了两种角度看待数据与模型的关系,被称作 consistent 视角与 mirrored 视角. 本文将介绍 ...
- ES6中的新特性:Iterables和iterators
目录 简介 什么是iteration Iterable对象 普通对象不是可遍历的 自定义iterables 关闭iterators 总结 简介 为了方便集合数据的遍历,在ES6中引入了一个iterat ...
- 【C++】Vector排序
1.普通类型(由大到小排序) int main() { sort(v.begin(),v.end()); } 2.普通类型(由小到大排序) bool comp(const int &a,con ...
- 解决git冲突
多个开发者同时操作git中的同一个文件,第一个人在commit和push的时候是可以正常提交的,而之后的开发者执行pull,就会报冲突异常conflict. 解决方案: 全部采用当前更改 之后再去gi ...
- 重新整理 .net core 实践篇—————工作单元模式[二十六]
前言 简单整理一下工作单元模式. 正文 工作单元模式有3个特性,也算是其功能: 使用同一上下文 跟踪实体的状态 保障事务一致性 工作单元模式 主要关注事务,所以重点在事务上. 在共享层的基础建设类库中 ...
- 裸辞闭关2个月,成功进大厂!吃透这份562页《算法知识手册》,化身offer收割机!
前言 记得我上本科的时候,我们老师一直跟我们强调:"算法才是编程的灵魂,一定要把算法学好."因为不管你是Java编程爱好者.还是python的忠实粉丝,亦或觉得PHP才是这个世界最 ...
- SpringBoot数据访问(三) SpringBoot整合Redis
前言 除了对关系型数据库的整合支持外,SpringBoot对非关系型数据库也提供了非常好的支持,比如,对Redis的支持. Redis(Remote Dictionary Server,即远程字典服务 ...
- .net core 支付宝,微信支付 一
源码: https://github.com/aspros-luo/Qwerty.Payment/tree/develop 支付宝支付:参考支付宝sdk及文档,https://docs.open.al ...
- Custom Controller CollectionQT样式自定义 002 :NoteSlider 标签滑动条
先上效果图 这个效果可以根据需求再定制,比如说文本框换成一个点下出现的气泡,跟随游标移动. 思路:继承QSlider,重写鼠标事件,添加label部件,定义其动作事件 源码:https://githu ...
- 5、cobbler搭建本地saltstack yum仓库
5.1.安装cobbler: 参考"linux运维_集群_01(35.cobbler自动化安装操作系统:)" 5.2.cobbler yum源常用操作命令: cobbler rep ...