簡(jiǎn)單模式匹配:BruteForce算法

串的模式匹配操作

在學(xué)習(xí)BruteForce算法之前,我們先簡(jiǎn)單了解一下什么是串的模式匹配操作。

官方:在字符串匹配問(wèn)題中,我們期待查看S串(目標(biāo)串)中是否含有串T(模式串)。S:主串 T:子串。如果在主串中查找到了子串,則模式匹配成功,返回模式串中的第一個(gè)字符主串中的位置。如果未找到,則模式匹配失敗,返回-1。

說(shuō)白了,也就S串中看是否有T串,有就返回第一個(gè)字符匹配的位置,沒(méi)有就返回-1。

BruteForce算法

今天我們所講的BruteForce算法也稱簡(jiǎn)單匹配算法

基本思路:從目標(biāo)串 S = "S0S1.....Sn-1"(不會(huì)打下標(biāo) -.-)的第一個(gè)字符開始和模式串 T = "T0T1....Tm-1"中的第一個(gè)字符相比較,若相等,則繼續(xù)逐個(gè)比較,否則,從目標(biāo)串第二個(gè)字符重新與模式串T進(jìn)行比較,以此類推,直到匹配成功,或者匹配失敗。

舉個(gè)栗子:

假設(shè) 目標(biāo)串 S = "cddcdc" ?模式串 T = "cdc" 模式匹配過(guò)程如圖:


代碼實(shí)現(xiàn)!

BruteForce算法 總結(jié)

優(yōu)點(diǎn):簡(jiǎn)單明朗,便于實(shí)現(xiàn)記憶

缺點(diǎn):進(jìn)行了回溯,效率不高,并且很多對(duì)比匹配還是沒(méi)有必要的。

因此,更多時(shí)候還是應(yīng)該使用它的改進(jìn)算法:KMP算法。


留個(gè)小鋪墊,下一講我們將講解 KMP 算法的原理與實(shí)現(xiàn)。

PS:有什么問(wèn)題或者不解的地方可以評(píng)論,我都會(huì)一一就行回復(fù)的,如果有錯(cuò)誤或者言語(yǔ)不明的地方,還請(qǐng)大神多多指點(diǎn)!

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容