久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊(cè)

QQ登錄

只需一步,快速開始

搜索
查看: 3105|回復(fù): 0
收起左側(cè)

數(shù)據(jù)結(jié)構(gòu)KMP算法C語言源程序

[復(fù)制鏈接]
ID:618366 發(fā)表于 2020-4-23 14:34 | 顯示全部樓層 |閱讀模式
1.概述.
快速模式匹配算法,簡稱 KMP 算法,是在 BF 算法基礎(chǔ)上改進(jìn)得到的算法。 BF 算的實(shí)現(xiàn)過程就是 "傻瓜式" 地用模式串(假定為子串的串)與主串中的字符一一匹配,算法執(zhí)行效率不高,所以為了減少算法的時(shí)間復(fù)雜度,特引出KMP算法
2.基本原理
example:
7]7VWSX@O}8Z069B_QEYA{L.png

由此可以看出,每次匹配失敗后模式串移動(dòng)的距離不一定是 1,某些情況下一次移動(dòng)多個(gè)位置,這就是 KMP 模式匹配算法
模式串移動(dòng)距離的判斷:
每次模式匹配失敗后,計(jì)算模式串向后移動(dòng)的距離是 KMP 算法中的核心部分。
其實(shí),
匹配失敗后模式串移動(dòng)的距離和主串沒有關(guān)系,只與模式串本身有關(guān)系。
給每個(gè)模式串配備一個(gè)數(shù)組(例如 next[]),用于存儲(chǔ)模式串中每個(gè)字符對(duì)應(yīng)指針 j 重定向的位置(也就是存儲(chǔ)模式串的數(shù)組下標(biāo)),比如 j=4,則該字符匹配失敗后指針 j 指向模式串中第4 個(gè)字符
3.實(shí)現(xiàn) next 數(shù)組的 C 語言代碼:
2.png



4.next 數(shù)組的缺陷及改進(jìn)
3.gif

當(dāng)匹配失敗時(shí),Next 函數(shù) 開始繼續(xù)進(jìn)行模式匹配,但是從圖中可以看到,這樣做是沒有必要的,純屬浪費(fèi)時(shí)間

出現(xiàn)這種多余的操作,問題在當(dāng) T[i-1]==T[j-1] 成立時(shí),沒有繼續(xù)對(duì) i++ 和 j++ 后的 T[i-1] 和 T[j-1] 的值做判斷。改進(jìn)后的 Next 函數(shù)如下所示:
4.png
5.KMP的實(shí)現(xiàn):附件 cKMP算法.rar (1.18 KB, 下載次數(shù): 12)

評(píng)分

參與人數(shù) 1黑幣 +50 收起 理由
admin + 50 共享資料的黑幣獎(jiǎng)勵(lì)!

查看全部評(píng)分

回復(fù)

使用道具 舉報(bào)

本版積分規(guī)則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 亚洲久热| 黄色片毛片| 国产精品久久网 | 中文字幕的| 欧美日韩四区 | 一区二区免费在线观看 | 欧美亚洲在线 | 日韩不卡av | 国产精品xxx在线观看 | 国产精品久久久久久久久久久久久 | 激情婷婷网 | 国产美女av | 亚洲免费观看视频 | 神马九九 | 国产综合久久久 | 日本少妇中文字幕 | 思思在线视频 | 日韩成人免费视频 | 中文字幕在线观看免费视频 | 成人爽a毛片一区二区免费 亚洲午夜在线观看 | 国产成人99久久亚洲综合精品 | 日韩精品久久 | 91久久国产综合久久91精品网站 | 欧美一区二区在线播放 | 中文字幕亚洲欧美 | 欧洲一区二区 | 天堂在线中文资源 | 日韩欧美视频一区 | 欧美一区二区免费 | 日韩成人免费视频 | 国产欧美一区二区精品忘忧草 | 亚洲精品一区二区三区蜜桃久 | 欧美一区二区三区免费 | 黄色免费大片 | 亚洲福利专区 | 久久免费网| 精久久久久 | 秋霞一区二区三区 | 伊人网在线视频 | 黄色天天影视 | 精品国产欧美一区二区三区成人 |