>  기사  >  백엔드 개발  >  PHP는 KMP 알고리즘을 구현합니다.

PHP는 KMP 알고리즘을 구현합니다.

不言
不言원래의
2018-04-10 17:28:412303검색


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=&#39;ABCDABD&#39;;$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,&#39;ABD&#39;));

참조

[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는 간단한 계산기를 구현합니다


PHP는 간단한 Redis 문서 잠금을 구현하고 동시 반복 호출을 방지합니다

위 내용은 PHP는 KMP 알고리즘을 구현합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.