in place 字串替換 利用KMP匹配

2021-06-13 13:58:00 字數 1139 閱讀 4862

實現字串替換

假設原字串長度足夠大, replaced 字串 和 new 字串的 長度沒有限制

演算法中用到了 kmp 的匹配演算法

//#include "stdafx.h"

#include #include /**

* @brief calckmpnext 計算kmp演算法需要的next陣列

* * @param keyword 關鍵字

* @param keywordlen 關鍵字長度

* @param next 儲存next

*/void calckmpnext(const char* keyword, const int keywordlen, char* next)

}free(next);

return -1;

}int calcstrtimes(char *array, char *pattern)

else

}return count;

}char* replace2(char *array, char* oldstr, char* newstr)

else

pcur = array + siftdistance;

} pnew = array;

int oldstrpos = kmpsearch(pcur, oldstr);

while (pcur < &array[0]+arrstrlen+siftdistance)

memcpy(pnew, newstr, newstrlen);

pcur += oldstrlen;

pnew += newstrlen;

oldstrpos = kmpsearch(pcur, oldstr);

} else

}*pnew = '\0';

return array;

}int _tmain(int argc, _tchar* argv)

; memcpy(a, "abcdef345kdgfaxyzfereaxyzeewaxyzdf", 34);

printf("%s\n", a);

replace2(a, "xyz", "ccic");

printf("%s\n", a);

return 0;

}

字串替換

描述輸入乙個字串,以回車結束 字串長度 100 該字串由若干個單詞組成,單詞之間用乙個空格隔開,所有單詞區分大小寫。現需要將其中的某個單詞替換成另乙個單詞,並輸出替換之後的字串。輸入輸入包括3行,第1行是包含多個單詞的字串 s,第2行是待替換的單詞a,長度 100 第3行是a將被替換的單詞b。長度 ...

字串替換

一 問題 函式宣告如下 char strreplace char str,char sub,char rep 其中str為原字串,sub為待被替換的子串。為簡單起見,假定字串sub和rep長度一樣 二 源 char strreplace char str,char sub,char rep if f...

字串替換

請你實現乙個簡單的字串替換函式。原串中需要替換的佔位符為 s 請按照引數列表的順序一一替換佔位符。若引數列表的字元數大於佔位符個數。則將剩下的引數字元新增到字串的結尾。給定乙個字串a,同時給定它的長度n及引數字元陣列arg,請返回替換後的字串。保證引數個數大於等於佔位符個數。保證原串由大小寫英文本母...