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

溫馨提示×

溫馨提示×

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

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

C++算法庫中的KMP字符串匹配

發布時間:2024-08-13 12:41:28 來源:億速云 閱讀:86 作者:小樊 欄目:編程語言

KMP算法(Knuth-Morris-Pratt算法)是一種用于字符串匹配的算法,用于在一個文本串中查找一個模式串的出現位置。KMP算法的主要思想是利用已經匹配過的信息來盡量減少比較的次數。

以下是一個簡單的C++實現KMP字符串匹配的示例代碼:

#include <iostream>
#include <vector>

void computeLPSArray(std::string pattern, std::vector<int>& lps) {
    int M = pattern.length();
    int len = 0;
    lps[0] = 0;
    
    int i = 1;
    while (i < M) {
        if (pattern[i] == pattern[len]) {
            len++;
            lps[i] = len;
            i++;
        } else {
            if (len != 0) {
                len = lps[len - 1];
            } else {
                lps[i] = 0;
                i++;
            }
        }
    }
}

void KMP(std::string text, std::string pattern) {
    int N = text.length();
    int M = pattern.length();
    
    std::vector<int> lps(M, 0);
    computeLPSArray(pattern, lps);
    
    int i = 0, j = 0;
    while (i < N) {
        if (pattern[j] == text[i]) {
            i++;
            j++;
        }
        
        if (j == M) {
            std::cout << "Pattern found at index " << i - j << std::endl;
            j = lps[j - 1];
        } else if (i < N && pattern[j] != text[i]) {
            if (j != 0) {
                j = lps[j - 1];
            } else {
                i++;
            }
        }
    }
}

int main() {
    std::string text = "ABABDABACDABABCABAB";
    std::string pattern = "ABABCABAB";
    
    KMP(text, pattern);
    
    return 0;
}

在上面的代碼中,computeLPSArray函數用于計算模式串的最長前綴后綴數組(LPS),KMP函數用于在文本串中查找模式串的出現位置。通過以上代碼,您可以在C++中實現KMP算法來進行字符串匹配。

向AI問一下細節

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

c++
AI

建平县| 井冈山市| 翁源县| 海淀区| 无为县| 犍为县| 平和县| 托克托县| 泗阳县| 岳阳县| 雷州市| 枝江市| 洛川县| 天峨县| 石狮市| 女性| 宜川县| 新巴尔虎左旗| 同仁县| 垫江县| 瑞安市| 广西| 新沂市| 宁安市| 马龙县| 巴塘县| 泰宁县| 剑河县| 银川市| 怀集县| 得荣县| 琼海市| 渝中区| 曲松县| 榆树市| 崇礼县| 浦城县| 湘潭县| 海阳市| 平遥县| 宁武县|