Heim  >  Artikel  >  Backend-Entwicklung  >  PHP implementiert den KMP-Algorithmus

PHP implementiert den KMP-Algorithmus

不言
不言Original
2018-04-10 17:28:412320Durchsuche


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;));

Referenz

[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=&#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;));

Referenz

[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)

Verwandte Empfehlungen:

PHP implementiert Additions- und Subtraktions-Verifizierungscodes

PHP implementiert einen einfachen Taschenrechner

PHP implementiert eine einfache Redis-Dokumentsperre und verhindert gleichzeitige wiederholte Aufrufe

Das obige ist der detaillierte Inhalt vonPHP implementiert den KMP-Algorithmus. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn