国产免费AV|泡泡玛特欧洲总部将设在伦敦|中文天堂网www新版资源在线|一本久道综合在线中文|国精产品一二三产区的使用方法|香蕉鱼在线观看|www.27eee

 找回密碼
 注冊
搜索

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

[復制鏈接]
樓主
coolice 發表于 2020-4-25 17:08:09 | 只看該作者 |只看大圖 |倒序瀏覽 |閱讀模式
1.概述.
快速模式匹配算法,簡稱 KMP 算法,是在 BF 算法基礎上改進得到的算法。 BF 算的實現過程就是 "傻瓜式" 地用模式串(假定為子串的串)與主串中的字符一一匹配,算法執行效率不高,所以為了減少算法的時間復雜度,特引出KMP算法
2.基本原理
example:
數據結構KMP算法C語言源程序 140712pzf9oshf47trhbo0.png

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



4.next 數組的缺陷及改進
數據結構KMP算法C語言源程序 142653b09o45z27ex92pns.gif

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

出現這種多余的操作,問題在當 T[i-1]==T[j-1] 成立時,沒有繼續對 i++ 和 j++ 后的 T[i-1] 和 T[j-1] 的值做判斷。改進后的 Next 函數如下所示:
數據結構KMP算法C語言源程序 142754nttblob0fe3ou3ot.png
5.KMP的實現:附件 KMP算法C源碼.rar (1.18 KB, 售價: 1 E幣)
您需要登錄后才可以回帖 登錄 | 注冊

本版積分規則

手機版|小黑屋|ELEOK |網站地圖

GMT+8, 2026-5-26 04:02

Powered by Discuz! X5.0

© 2001-2026 Discuz! Team.

快速回復 返回頂部 返回列表