Rumah >pembangunan bahagian belakang >tutorial php >Kuasai algoritma KMP antara algoritma padanan rentetan dalam PHP, dan apakah teknik untuk meningkatkan kelajuan padanan corak?

Kuasai algoritma KMP antara algoritma padanan rentetan dalam PHP, dan apakah teknik untuk meningkatkan kelajuan padanan corak?

王林
王林asal
2023-09-20 11:12:23858semak imbas

Kuasai algoritma KMP antara algoritma padanan rentetan dalam PHP, dan apakah teknik untuk meningkatkan kelajuan padanan corak?

Apakah teknik untuk menguasai algoritma KMP dalam algoritma pemadanan rentetan dalam PHP dan meningkatkan kelajuan pemadanan corak?

#🎜🎜 #Algoritma KMP (Algoritma Knuth-Morris-Pratt) ialah algoritma pemadanan rentetan yang cekap yang boleh mencapai padanan corak rentetan dalam kerumitan masa O(n+m). Dalam PHP, menguasai algoritma KMP boleh meningkatkan kelajuan pemadanan rentetan, terutamanya apabila memproses sejumlah besar teks. Artikel ini akan memperkenalkan prinsip algoritma KMP dan menyediakan contoh kod PHP untuk menunjukkan penggunaannya.

    Prinsip algoritma KMP
  1. Idea teras algoritma KMP ialah apabila memadankan antara rentetan corak dan rentetan sasaran, tidak perlu mengundur semua yang dibandingkan aksara apabila perlawanan gagal , tetapi menggunakan maklumat yang telah dipadankan untuk melangkau beberapa aksara, dengan itu meningkatkan kecekapan pemadanan. Algoritma KMP melaksanakan operasi melangkau aksara dengan mengira akhiran biasa terpanjang bagi rentetan corak, iaitu, mendapatkan tatasusunan seterusnya melalui prapemprosesan untuk menunjukkan bilangan aksara yang harus dilangkau apabila perlawanan gagal.
  2. Bina tatasusunan seterusnya
  3. Dalam algoritma KMP, anda perlu terlebih dahulu membina tatasusunan seterusnya untuk menunjukkan bilangan aksara yang harus dilangkau apabila perlawanan gagal. Contoh kod PHP diberikan di bawah untuk menunjukkan cara membina tatasusunan seterusnya:
  4. function buildNextArray($pattern) {
        $len = strlen($pattern);
        $next = array_fill(0, $len, 0);
        $next[0] = -1;
        
        $i = 0; 
        $j = -1;
        
        while ($i < $len - 1) {
            if ($j == -1 || $pattern[$i] == $pattern[$j]) {
                $i++;
                $j++;
                $next[$i] = $j;
            } else {
                $j = $next[$j];
            }
        }
        
        return $next;
    }
    padanan algoritma KMP
  1. Dengan tatasusunan seterusnya yang dibina sebelum ini, kita boleh menggunakan Algoritma KMP untuk padanan rentetan. Contoh kod PHP diberikan di bawah untuk menunjukkan proses pemadanan algoritma KMP:
  2. function kmpMatch($text, $pattern) {
        $textLen = strlen($text);
        $patternLen = strlen($pattern);
        $next = buildNextArray($pattern);
        
        $i = 0; 
        $j = 0;
        
        while ($i < $textLen && $j < $patternLen) {
            if ($j == -1 || $text[$i] == $pattern[$j]) {
                $i++;
                $j++;
            } else {
                $j = $next[$j];
            }
        }
        
        if ($j == $patternLen) {
            return $i - $j;
        }
        
        return -1;
    }
    Gunakan algoritma KMP untuk pemadanan rentetan
  1. Gunakan algoritma KMP untuk pemadanan rentetan Sangat mudah. Berikut ialah contoh kod PHP yang menggunakan algoritma KMP untuk pemadanan rentetan:
  2. $text = "ABABABACDABABCABABCAB";
    $pattern = "ABABCAB";
    
    $index = kmpMatch($text, $pattern);
    
    if ($index != -1) {
        echo "匹配成功,首次出现位置:".$index;
    } else {
        echo "未找到匹配的子串";
    }
Dalam contoh di atas, "Pemadanan berjaya, kedudukan kejadian pertama: 7" akan dikeluarkan, yang ialah, dalam Rentetan corak $pattern dipadankan dalam rentetan sasaran $teks, dan kejadian pertama adalah pada indeks 7.

Dengan menguasai algoritma KMP, kami boleh melakukan pemadanan rentetan dalam PHP dengan cekap, mengurangkan perbandingan aksara yang tidak perlu dan menjejak ke belakang, sekali gus meningkatkan kelajuan pemadanan corak. Melalui pengenalan dan contoh kod artikel ini, saya percaya bahawa pembaca akan mempunyai pemahaman yang lebih mendalam tentang prinsip dan pelaksanaan algoritma KMP, dan boleh menggunakan pengetahuan ini dalam projek sebenar untuk meningkatkan kecekapan padanan rentetan.

Atas ialah kandungan terperinci Kuasai algoritma KMP antara algoritma padanan rentetan dalam PHP, dan apakah teknik untuk meningkatkan kelajuan padanan corak?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn