PTA刷題之KMP算法--記錄自己的粗淺理解

 

來源是PTA的一道題,一開始是想用KMP算法來做,但是發現沒有這麼難,普通邏輯處理就可以

以下爲題目:

L1-058 6翻了 (15分)

 

“666”是一種網絡用語,大概是表示某人很厲害、我們很佩服的意思。最近又衍生出另一個數字“9”,意思是“6翻了”,實在太厲害的意思。如果你以爲這就是厲害的最高境界,那就錯啦 —— 目前的最高境界是數字“27”,因爲這是 3 個 “9”!

本題就請你編寫程序,將那些過時的、只會用一連串“6666……6”表達仰慕的句子,翻譯成最新的高級表達。

輸入格式:

輸入在一行中給出一句話,即一個非空字符串,由不超過 1000 個英文字母、數字和空格組成,以回車結束。

輸出格式:

從左到右掃描輸入的句子:如果句子中有超過 3 個連續的 6,則將這串連續的 6 替換成 9;但如果有超過 9 個連續的 6,則將這串連續的 6 替換成 27。其他內容不受影響,原樣輸出。

輸入樣例:

it is so 666 really 6666 what else can I say 6666666666

輸出樣例:

it is so 666 really 9 what else can I say 27

 KMP算法的來源就不過介紹了,相關的文章也有很多,下面我結合代碼講下我自己的思路,希望對讀了這篇文章的人加深點理解

void GetNext(string str,int next[] )
{//next下標從0開始
    int i = 0, j = -1;
    next[0] = -1;
    while (i<str.length()-1)
    {
        if (j == -1 || str[i] == str[j])
        {
             ++i; ++j; next[i] = j;
        }
        else
            j = next[j];
    }
}

先說下next數組的作用,next[i]的值就代表主串要移動的位數

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章