PHP实现KMP算法
程序员文章站
2022-03-08 13:08:39
...
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算法的详细内容,更多请关注其它相关文章!
上一篇: 用range函数创建数组
下一篇: php面试题四之实现autoload