PHP实现KMP算法
程序员文章站
2022-03-15 13:36:00
...
function cal_next($str){ $next[0] = -1;//next[0]初始化为-1 $i=0; $j = -1; $len=strlen($str); while($i<$len){ if($j===-1 || $str[$i]===$str[$j]){ $i++; $j++; $next[$i]=$j; }else{ $j=$next[$j]; } } return $next; }$str='ABCDABD';$next=cal_next($str); var_dump($next);function search($str,$search){ $next=cal_next($search); $i=0; $j=0; $lenStr=strlen($str); $lenSearch=strlen($search); while($i<$lenStr && $j<$lenSearch){ if($j===-1 || $str[$i]===$search[$j]){ //$i 主串的不后退,移动模式串。为什么没有$j===0,因为如果有$j++为1,下一步是判断$str[$i]===$search[1],跳过了$search[0] $i++; $j++; }else{ $j=$next[$j]; } } if($j===$lenSearch){ return $i-$j; } return -1; } var_dump(search($str,'ABD'));
参考
[KMP算法(1):如何理解KMP](https://segmentfault.com/a/1190000008575379) [字符串匹配的KMP算法](http://www.ruanyifeng.com/blog/2013/05/Knuth%E2%80%93Morris%E2%80%93Pratt_algorithm.html) [KMP算法最浅显理解](https://blog.csdn.net/starstar1992/article/details/54913261)
function cal_next($str){ $next[0] = -1;//next[0]初始化为-1 $i=0; $j = -1; $len=strlen($str); while($i<$len){ if($j===-1 || $str[$i]===$str[$j]){ $i++; $j++; $next[$i]=$j; }else{ $j=$next[$j]; } } return $next; }$str='ABCDABD';$next=cal_next($str); var_dump($next);function search($str,$search){ $next=cal_next($search); $i=0; $j=0; $lenStr=strlen($str); $lenSearch=strlen($search); while($i<$lenStr && $j<$lenSearch){ if($j===-1 || $str[$i]===$search[$j]){//$i 主串的不后退,移动模式串。为什么没有$j===0,因为如果有$j++为1,下一步是判断$str[$i]===$search[1],跳过了$search[0] $i++; $j++; }else{ $j=$next[$j]; } } if($j===$lenSearch){ return $i-$j; } return -1; } var_dump(search($str,'ABD'));
参考
[KMP算法(1):如何理解KMP](https://segmentfault.com/a/1190000008575379) [字符串匹配的KMP算法](http://www.ruanyifeng.com/blog/2013/05/Knuth%E2%80%93Morris%E2%80%93Pratt_algorithm.html) [KMP算法最浅显理解](https://blog.csdn.net/starstar1992/article/details/54913261)
相关推荐:
以上就是PHP实现KMP算法的详细内容,更多请关注其它相关文章!
上一篇: javascript如何修改html
下一篇: css中鼠标点击的五种状态分别是什么
推荐阅读
-
php利用正则表达式实现手机号码格式验证代码
-
挖掘PHP上传文件类型原理实现_PHP教程
-
php结合md5实现的加密解密方法,php结合md5加密解密_PHP教程
-
PHP实现自动识别Restful API的返回内容类型
-
php日期格式 php实现常见图片格式的水印和缩略图制作面向对象
-
[PHP]利用XAMPP搭建本地服务器, 然后利用iOS客户端上传数据到本地服务器中(三. PHP端代码实现) - M_Lee
-
php实现简单的语法高亮函数实例分析
-
PHP 数据结构 算法 三元组 Triplet_php技巧
-
使用PHP实现密保卡功能实现代码<打包下载直接运行>
-
PHP实现点击导航菜单只改变底下内容模块