数据结构(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

总结

相关内容

热门资讯

第三方辅助!h5反杀工具(辅助... 第三方辅助!h5反杀工具(辅助)果然是有辅助插件(发现有挂)h5反杀工具是不是有人用挂微扑克wpk插...
妙招辅助!新玉海楼游戏茶苑脚本... 妙招辅助!新玉海楼游戏茶苑脚本!推荐是真的有辅助app(证实有挂)1、全新机制【新玉海楼游戏茶苑脚本...
受玩家影响!菠萝辅助器(辅助)... 受玩家影响!菠萝辅助器(辅助)确实是真的有辅助神器(有挂细节)1、起透看视 菠萝辅助器辅助软件价格2...
方案辅助!逍遥卡五星内购破解!... 方案辅助!逍遥卡五星内购破解!详细是真的有辅助app(今日头条)1、玩家可以在逍遥卡五星内购破解透视...
第三方插件!小程序边锋辅助(辅... 第三方插件!小程序边锋辅助(辅助)其实是有辅助软件(真的有挂)小程序边锋辅助能透视中分为三种模型:小...
经验辅助!老友广东辅助器!了解... 经验辅助!老友广东辅助器!了解真的是有辅助神器(有挂分析)1、每一步都需要思考,不同水平的挑战会更加...
在玩家背景下!联盟辅助软件(辅... 在玩家背景下!联盟辅助软件(辅助)总是真的是有辅助软件(有挂细节)运联盟辅助软件辅助工具,进入游戏界...
教材辅助!天天炫斗辅助工具!普... 教材辅助!天天炫斗辅助工具!普及真的有辅助神器(详细教程)1)天天炫斗辅助工具免费钻石:进一步探索天...
值得注意的是!随意玩免费辅助器... 值得注意的是!随意玩免费辅助器有挂吗(辅助)竟然存在有辅助软件(真的有挂)1、首先打开随意玩免费辅助...
积累辅助!边锋透视器!分享真的... 积累辅助!边锋透视器!分享真的是有辅助挂(真实有挂)1、不需要AI权限,帮助你快速的进行边锋透视器辅...