91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

PHP如何實現用于模式搜索的樸素算法

發布時間:2020-10-15 17:21:43 來源:億速云 閱讀:157 作者:小新 欄目:編程語言

小編給大家分享一下PHP如何實現用于模式搜索的樸素算法,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

給定文本txt [0..n-1]和模式pat [0..m-1],編寫一個函數搜索(char pat [],char txt []),在txt中打印所有出現的pat [] []。你可以假設n> m

例子:

輸入:  txt[] = "THIS IS A TEST TEXT"
        pat[] = "TEST"
輸出: Pattern found at index 10

輸入:  txt[] =  "AABAACAADAABAABA"
        pat[] =  "AABA"
輸出: Pattern found at index 0
        Pattern found at index 9
        Pattern found at index 12

PHP如何實現用于模式搜索的樸素算法

模式(Pattern )搜索是計算機科學中的一個重要問題。當我們在記事本、 word文件、瀏覽器或數據庫中搜索字符串時,使用模式搜索算法來顯示搜索結果。

樸素模式搜索:
將模式逐個滑過文本并檢查是否匹配。如果找到匹配項,則再次滑動1以檢查后續匹配項。

PHP代碼:

<?php 
// 樸素模式搜索算法
  
function search($pat, $txt) 
{ 
    $M = strlen($pat); 
    $N = strlen($txt); 
  
    for ($i = 0; $i <= $N - $M; $i++) 
    { 
  
        // 對于當前索引i,請檢查模式匹配
        for ($j = 0; $j < $M; $j++) 
            if ($txt[$i + $j] != $pat[$j]) 
                break; 
  
        // if pat[0...M-1] =  
        // txt[i, i+1, ...i+M-1] 
        if ($j == $M)  
            echo "Pattern found at index ", $i."\n"; 
    } 
} 
  
    $txt = "AABAACAADAABAAABAA"; 
    $pat = "AABA"; 
    search($pat, $txt);

輸出:

Pattern found at index 0 
Pattern found at index 9 
Pattern found at index 13

什么是最好的情況?

當Pattern模式的第一個字符根本不存在于文本中時,會出現最佳情況。

filter_none
brightness_4
txt[] = "AABCCAADDEE"; 
pat[] = "FAA";

最佳情況下的比較次數為O(n)

什么是最壞的情況?

1)當文本和圖案的所有字符相同時。

filter_none
brightness_4
txt[] = "AAAAAAAAAAAAAAAAAA"; 
pat[] = "AAAAA";

2)當最后一個字符不同時,也會出現最壞情況。

filter_none
brightness_4
txt[] = "AAAAAAAAAAAAAAAAAB"; 
pat[] = "AAAAB";

最壞情況下的比較次數是O(m *(n-m + 1))。雖然具有重復字符的字符串不太可能出現在英文文本中,但它們很可能出現在其他應用程序中(例如,在二進制文本中)。

以上是PHP如何實現用于模式搜索的樸素算法的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

应城市| 建昌县| 溆浦县| 云南省| 巫溪县| 曲阜市| 苍南县| 恭城| 洛阳市| 财经| 沅江市| 廊坊市| 吉安市| 宁陕县| 阳城县| 阳山县| 志丹县| 天祝| 石嘴山市| 亳州市| 乐昌市| 江北区| 安化县| 苍梧县| 鲁山县| 日照市| 永泰县| 苏尼特右旗| 手机| 蒙山县| 云梦县| 厦门市| 吐鲁番市| 咸宁市| 镇坪县| 安康市| 宝清县| 台湾省| 海城市| 西昌市| 康保县|