数据结构-4.4.朴素模式匹配算法

一.专业术语:

注:子串和模式串有区别。


二.朴素模式匹配算法:

思路:在主串中找出所有与模式串长度相等的子串,与模式串进行比较,如果找到了,返回子串第一个字符在主串的位置

1.使用字符串的基本操作实现朴素模式匹配算法:

2.不使用字符串的基本操作实现朴素模式匹配算法:

思路:先在主串中找出所有与模式串长度相等的子串,设置两个指针,一开始分别指向主串子串模式串的第一个字

符,这两个指针指到哪儿就把字符对比到哪儿,一开始比第一个字符,如果相等,这两个指针都后移继续比较下一

个字符,不相等的话将主串中下一个与模式串长度相等的子串和模式串进行比较,以此类推:

上述图片中j当前的值说明匹配到子串中的第几个字符,i-j让i的值回到目前子串的前面一个位置,因为i和j此时一起向前移,但最终是想让主串指针i指向下一个子串的第一个位置,因此要加2,最终i=i-j+2:

经过一系列匹配,最终在主串中找到了与模式串相等的子串,此时模式串里的指针j最终指向了模式串外的一个位置:

3.代码:其中主串为S,模式串为T,i和j为分别指向主串子串模式串的第一个字符的指针

最终匹配失败返回0较好,因为主串S中0索引上不存元素,返回0相当于返回一个不存在的内容;

对于时间复杂度:

先考虑最坏的情况:首先主串中第一个长度和模式串相同的子串与模式串相比较,比到模式串最后一个字符才发现有不同的,换到主串中第二个长度和模式串相同的子串与模式串相比较,也是比到模式串最后一个字符才发现有不同的,以此类推(注:主串长度为n,模式串长度为m):

最坏的情况就是主串中每个子串都要与模式串对比m个字符(也就是比到模式串最后一个字符才发现匹配失败),一共对比

主串中n-m+1个子串即可,所以时间复杂度为O( m * (n-m+1) ) = O( m * n - m * m + m ),等价于O(m * n),注:很多时候

n远大于m(因为主串长度为n,模式串长度即要找的串的长度为m,如一篇文章找一个词,文章远大于词),因此n * m远大

于m * m,所以时间复杂度里m * m可以省掉,m也可以省掉。


三.总结:


相关推荐
晨晖236 分钟前
顺序查找:c语言
c语言·开发语言·算法
LYFlied1 小时前
【每日算法】LeetCode 64. 最小路径和(多维动态规划)
数据结构·算法·leetcode·动态规划
Salt_07281 小时前
DAY44 简单 CNN
python·深度学习·神经网络·算法·机器学习·计算机视觉·cnn
货拉拉技术1 小时前
AI拍货选车,开启拉货新体验
算法
MobotStone2 小时前
一夜蒸发1000亿美元后,Google用什么夺回AI王座
算法
Wang201220132 小时前
RNN和LSTM对比
人工智能·算法·架构
xueyongfu2 小时前
从Diffusion到VLA pi0(π0)
人工智能·算法·stable diffusion
永远睡不够的入2 小时前
快排(非递归)和归并的实现
数据结构·算法·深度优先
cheems95272 小时前
二叉树深搜算法练习(一)
数据结构·算法
sin_hielo2 小时前
leetcode 3074
数据结构·算法·leetcode