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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 3058|回復: 0
收起左側

數據結構KMP算法C語言源程序

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

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



4.next 數組的缺陷及改進
3.gif

當匹配失敗時,Next 函數 開始繼續進行模式匹配,但是從圖中可以看到,這樣做是沒有必要的,純屬浪費時間

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

評分

參與人數 1黑幣 +50 收起 理由
admin + 50 共享資料的黑幣獎勵!

查看全部評分

回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 亚洲一区在线日韩在线深爱 | 国产小视频自拍 | 九九爱这里只有精品 | 一区二区三区电影网 | 99精品视频一区二区三区 | 日韩精品视频在线观看一区二区三区 | 欧美激情在线一区二区三区 | 亚洲精品电影网在线观看 | 欧美精品在线一区二区三区 | 欧美一级电影免费观看 | 国产综合久久 | 四虎影院在线观看av | 在线欧美a | 二区三区视频 | 国产999精品久久久 精品三级在线观看 | 一区中文字幕 | 日本超碰 | 亚洲成人综合社区 | 精品久久一区 | 一级黄色片免费 | 欧美一区二区在线播放 | www网站在线观看 | 亚洲美女视频 | 久久久精品一区二区 | 亚洲国产一区二区三区 | 国产日韩欧美 | 精品久久久久久亚洲综合网 | 精品欧美一区二区中文字幕视频 | 国产高清精品一区 | 国产日韩欧美在线播放 | 色综合天天综合网国产成人网 | 精品国产一区二区在线 | 视频一二三区 | 欧美日韩在线视频一区 | 国产视频一区二区三区四区五区 | 蜜臀久久 | 激情欧美一区二区三区中文字幕 | 欧美激情 亚洲 | 人人人干 | 99久久久久 | 东京久久 |