>백엔드 개발 >PHP 튜토리얼 >문자열 일치 알고리즘의 일요일 알고리즘을 구현하는 PHP의 예

문자열 일치 알고리즘의 일요일 알고리즘을 구현하는 PHP의 예

黄舟
黄舟원래의
2017-12-06 13:48:355736검색

우리는 개발 과정에서 다양한 알고리즘을 자주 접하게 됩니다. 많은 친구들도 매칭 알고리즘을 알고 있을 것입니다. 문자열우리가 가장 자주 사용하는 알고리즘은 PHP 구현에 대한 자세한 소개입니다. 문자열 매칭 알고리즘 일요일 알고리즘!

문자열 일치 알고리즘을 위한 일요일 알고리즘을 구현하는 PHP의 예

<?php
/*
 *@param $pattern 模式串
 *@param $text 待匹配串
 */
function mySunday($pattern = &#39;&#39;,$text = &#39;&#39;){
    if(!$pattern || !$text) return false;
    $pattern_len = mb_strlen($pattern);
    $text_len = mb_strlen($text);
    if($pattern_len >= $text_len) return false;
    $i = 0;
    for($i = 0; $i < $pattern_len; $i++){ //组装以pattern中的字符为下标的数组
        $shift[$pattern[$i]] = $pattern_len - $i;
    }
    while($i <= $text_len - $pattern_len){
        $nums = 0;     //匹配上的字符个数
        while($pattern[$nums] == $text[$i + $nums]){
            $nums++;
            if($nums == $pattern_len){
                return "The first match index is $i\n";
            }
        }
        if($i + $pattern_len < $text_len && isset($shift[$text[$i + $pattern_len]])){ //判断模式串后一位字符是否在模式串中
            $i += $shift[$text[$i + $pattern_len]];      //对齐该字符
        }else{
            $i += $pattern_len;      //直接滑动pattern_len位
        }
    }
}
$text = "I am testing mySunday on sunday!";
$pattern = "sunday";
echo mySunday($pattern,$text);

요약:

이 문서에서는 코드 예제를 사용하여 문자열 일치 알고리즘을 보다 직관적으로 구현하는 PHP의 일요일 알고리즘을 설명합니다. 더 잘 이해하셔서 업무에 도움이 되셨으면 좋겠습니다!

관련 권장 사항:

최대 순방향 일치 알고리즘 PHP 구현

php에서 가장 간단한 문자열 일치 알고리즘

PHP의 단일 문자열 일치 알고리즘의 예

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

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