数据结构(4.2)——朴素模式匹配算法
创始人
2025-01-08 09:32:11
0

字符串模式匹配

在主串中找到模式串相同的子串,并返回其所在的位置。

子串和模式串的区别 

子串:主串的一部分,一定存在

模式串:不一定能在主串中找到

字符串模式匹配

朴素模式匹配算法 

主串长度为n,模式串长度为m

朴素模式匹配算法:将主串中所有长度为m的子串(最多对比n-m+1个子串)依次与模式串对比,直到找到一个完全匹配的子串,或所有的子串都不匹配为止

 index定位操作就是使用朴素模式匹配算法实现的

使用数组下标匹配

// 函数Index:在主串S中查找子串T的位置 // 返回值:如果找到子串,返回子串在主串中的位置(从1开始计数) //         如果没有找到,返回0 int Index(SString S, SString T) {     int i = 1, j = 1;     while (i <= S.length && j <= T.length) {         if (S.ch[i] == T.ch[j]) {             ++i; ++j; // 如果当前字符匹配,继续比较下一个字符         } else {             i = i - j + 2; // i回退到下一个可能的子串的起始位置             j = 1; // j重置为1,重新开始匹配         }     }     if (j > T.length)         return i - T.length; // 如果找到子串,返回子串在主串中的位置     else         return 0; // 如果没有找到子串,返回0 } 

设主串长度为n,模式串长度为m,则最坏时间复杂度=O(nm)

最坏的情况,每个子串都要对比m个字符,共n-m+1个子串,复杂度=O((n-m+1)m)=O(nm) 

注:很多时候,n>>m

总结

相关内容

热门资讯

透视教材!拱趴大菠萝开挂方法,... 透视教材!拱趴大菠萝开挂方法,聚星ai辅助工具下载(透视)本来真的有透视神器(哔哩哔哩)1、不需要A...
第六分钟插件!微信小程序免费黑... 第六分钟插件!微信小程序免费黑科技,微乐小程序辅助工具哪里下载(本来是真的外挂app)-哔哩哔哩1、...
透视练习!hh poker辅助... 透视练习!hh poker辅助器先试用,hhpoker作必弊码(透视)原来存在有挂(哔哩哔哩)1、玩...
透视操作!wepoker有插件... 透视操作!wepoker有插件吗,wepoker透视底牌(透视)一直有透视插件(哔哩哔哩)1、超多福...
两分钟辅助!微乐小程序自建房透... 两分钟辅助!微乐小程序自建房透视下载,微乐自建房免费黑科技推荐(本来是真的外挂插件)-哔哩哔哩1、下...
透视大纲!哈糖大菠萝助手,德扑... 透视大纲!哈糖大菠萝助手,德扑之心免费透视(透视)竟然是有挂(哔哩哔哩)1、德扑之心免费透视免费脚本...
透视办法!aa poker辅助... 透视办法!aa poker辅助包,云扑克有透视吗(透视)好像真的是有脚本器(哔哩哔哩)1、首先打开云...
透视步骤!wepoker透视脚... 透视步骤!wepoker透视脚本免费app,impoker辅助(透视)原来是真的挂(哔哩哔哩)1、w...
第8分钟脚本!微信小程序免费黑... 第8分钟脚本!微信小程序免费黑科技,微信小程序微乐辅助器免费版v2.0免费(一直是真的外挂修改器)-...
透视诀窍!aapoker辅助软... 透视诀窍!aapoker辅助软件合法吗,aapoker破解侠是真的吗(透视)都是是真的脚本攻略(哔哩...