朴素的模式匹配算法(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模式匹配算法的更多相关文章

  1. C++编程练习(7)----“KMP模式匹配算法“字符串匹配

    子串在主串中的定位操作通常称做串的模式匹配. KMP模式匹配算法实现: /* Index_KMP.h头文件 */ #include<string> #include<sstream& ...

  2. 数据结构——串的朴素模式和KMP匹配算法

    一.朴素模式 假设我们要从主串S="goodgoogle"中找到子串T="google"的位置,步骤如下: i表示主串的当前位置下标,j表示子串的当前位置下标, ...

  3. [从今天开始修炼数据结构]串、KMP模式匹配算法

    [从今天开始修炼数据结构]基本概念 [从今天开始修炼数据结构]线性表及其实现以及实现有Itertor的ArrayList和LinkedList [从今天开始修炼数据结构]栈.斐波那契数列.逆波兰四则运 ...

  4. 串、KMP模式匹配算法

    串是由0个或者多个字符组成的有限序列,又名叫字符串. 串的比较: 串的比较是通过组成串的字符之间的编码来进行的,而字符的编码指的是字符在对应字符集中的序号. 计算机中常用的ASCII编码,由8位二进制 ...

  5. 《数据结构》之串的模式匹配算法——KMP算法

    //串的模式匹配算法 //KMP算法,时间复杂度为O(n+m) #include <iostream> #include <string> #include <cstri ...

  6. KMP模式匹配算法

    KMP模式匹配算法 相信很多人对于这个还有点不了解,或者说是不懂,下面,通过一道题,来解决软考中的这个问题! 正题: aaabaaa,其next函数值为多少? 对于这个问题,我们应该怎么做呢? 1.整 ...

  7. 线性表-串:KMP模式匹配算法

    一.简单模式匹配算法(略,逐字符比较即可) 二.KMP模式匹配算法 next数组:j为字符序号,从1开始. (1)当j=1时,next=0: (2)当存在前缀=后缀情况,next=相同字符数+1: ( ...

  8. 详细解读KMP模式匹配算法

    转载请注明出处:http://blog.csdn.net/fightlei/article/details/52712461 首先我们需要了解什么是模式匹配? 子串定位运算又称为模式匹配(Patter ...

  9. 字符串的朴素模式和KMP模式匹配

    先复习一下字符串指针: #include <iostream> #include <string.h> using namespace std; int main() { ch ...

随机推荐

  1. TensorFlow分布式在Amazon AWS上运行

    TensorFlow分布式在Amazon AWS上运行 Amazon AWS 提供采用 NVIDIA K8 GPU 的 P2.x 机器.为了能够使用,第一步还需要创建一个 Amazon AWS 账户, ...

  2. 主成分分析法(PCA)原理和步骤

    主成分分析法(PCA)原理和步骤 主成分分析(Principal Component Analysis,PCA)是一种多变量统计方法,它是最常用的降维方法之一,通过正交变换将一组可能存在相关性的变量数 ...

  3. Single Shot Multibox Detection (SSD)实战(下)

    Single Shot Multibox Detection (SSD)实战(下) 2. Training 将逐步解释如何训练SSD模型进行目标检测. 2.1. Data Reading and In ...

  4. python常识系列14-->正则表达式基础之re模块

    前言 勤奋的含义是今天的热血,而不是明天的决心,后天的保证. 一.正则表达式是什么? 描述了一种字符串匹配的模式(pattern) 功能一:用来检查一个字符串串是否含有某种子字符串 功能二:将匹配的子 ...

  5. ES6中的变量结构赋值

    小编的上一篇文章更新了es6中关于变量定义的问题,这篇文章继续来一些实用的干货,关于数组.对象的赋值问题.特别是在前后端合作项目的时候,对后端数据的拆分,还有就是对于函数的默认值的惰性赋值问题.看完下 ...

  6. 前端 JS 之 AJAX 简介及使用

    概述 AJAX 是一个缩写,它的全名是 Asynchronous JavaScript and XML,意思就是异步 JavaScript 和 XML,即用JavaScript执行异步网络请求. AJ ...

  7. 【Java编程实战】Metasploit_Java后门运行原理分析以及实现源码级免杀与JRE精简化

    QQ:3496925334 文章作者:MG1937 CNBLOG博客ID:ALDYS4 未经许可,禁止转载 某日午睡,迷迷糊糊梦到Metasploit里有个Java平台的远控载荷,梦醒后,打开虚拟机, ...

  8. Java双重循环

    在实际开发中我们常常遇到这样的问题,有A.B两个集合,这两个集合的某一个字段是相同的,要把A集合和B进行匹配,然后把A的值赋值给B例如: //上传图片 List<MultipartFile> ...

  9. Linux shell是什么

    shell概念: shell是一个命令行解释器,它为用户提供了一个向Linux内核发送请求以便运行程序的界面系统级程序,用户可以用shell启动,挂起,停止甚至编写一些程序. shell还是一个功能强 ...

  10. 关于Kubernetes(简称K8S)的开启及基本使用,基于Docker Desktop & WSL2

    背景介绍 Kubernetes(简称k8s)已成为目前业界容器编排的事实标准,其搭配Docker可建立非常高效便捷的高可扩展.高可用应用服务架构. Kubernetes的名字来自希腊语,意思是&quo ...