日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 人文社科 > 生活经验 >内容正文

生活经验

BF算法~

發(fā)布時間:2023/11/27 生活经验 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 BF算法~ 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

先來看BF算法是干嘛的

BF算法,即暴力(Brute Force)算法,是普通的模式匹配算法,BF算法的思想就是將目標(biāo)串S的第一個字符與模式串T的第一個字符進(jìn)行匹配,若相等,則繼續(xù)比較S的第二個字符和 T的第二個字符;若不相等,則比較S的第二個字符和T的第一個字符,依次比較下去,直到得出最后的匹配結(jié)果。BF算法是一種蠻力算法。(取自百度百科)

來看圖解詳細(xì)過程:

?還有在代碼中所說的不能以主串的越界條件來判斷是否將子串匹配完:

?

接下來來看代碼:

int BF_Search(const char* str, const char* sub, int pos)
{assert(str != NULL && sub != NULL);if (pos < 0 || pos >= strlen(str)){return -1;//pos = 0; 這種pos越界的情況默認(rèn)就是從頭開始}int len_str = strlen(str);  //主串的長度int len_sub = strlen(sub);   //子串的長度int i = pos;//主串開始遍歷的位置int j = 0; //子串開始的位置while (i < len_str && j < len_sub){if (sub[j] == str[i]){i++;j++;}else{i = i - j + 1;j = 0;}}//這會兒循環(huán)退出了 要不是i > len_str 或者就是 j > len_sub  又因?yàn)橹鞔欠裢顺霾荒艽碜哟c主串是否匹配成功  因此代碼為:if (j >= len_sub){return i - j;}else   //主串匹配完也沒和子串匹配成功  則沒有找到  返回-1{return -1;}}

“要努力,但不要著急,任何碩果累累的結(jié)果都是過程的慢慢積累”

總結(jié)

以上是生活随笔為你收集整理的BF算法~的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。