由三位前辈发表的一个模式匹配算法,可以大大避免重复遍历的情况,称之为克努特-莫里斯-普拉特算法,检查 KMP 算法。
又叫 快速模式匹配算法。
KMP 算法相比于 BF 算法,优势在于:在保证指针 i 不回溯的前提下,当匹配失败时,让模式串向右移动最大的距离;
并且可以在 O(n+m) 的时间数量级上完成对串的模式匹配操作。KMP 算法原理参考链接:CSDN nextval[1] = 0; int j = 0;
while (i<strlen(str)) @version v1.0 * @copyright Copyright By lizhuming, All Rights Reserved * @blog http://lx.gongxuanwang.com/sszt/7.htm{ if (j == 0 || str[j-1] == str[i-1])
原理:主串 S 与模式串 T 有部分相同子串时,可以简化朴素匹配算法中的循环流程 湖北遴选从子串最长前缀和最长后缀开始求。最长也少于前面字符个数。最长公共前缀的后面一个字符(指针 j)和匹配失败的那个字符(指针 i)进行对比。于模式串中的某一字符来说,提取它前面的字符串,分别从字符串的两端查看连续相同的字符串的个数,在其基础上 +1 ,结果就是该字符对应的值。
湖北遴选字符对应 next 是第 0 个字符对应 next 数组下标为 1 开始的。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。
扫码关注腾讯云开发者
领取腾讯云代金券
Copyright © 2013 - 2025 Tencent Cloud. All Rights Reserved. 腾讯云 版权所有
深圳市腾讯计算机系统有限公司 ICP备案/许可证号:粤B2-20090059 深公网安备号 44030502008569
腾讯云计算(北京)有限责任公司 京ICP证150476号 | 京ICP备11018762号 | 京公网安备号11010802020287
Copyright © 2013 - 2025 Tencent Cloud.
All Rights Reserved. 腾讯云 版权所有