KMP 算法實例詳解
KMP 算法實例詳解
KMP算法,是由Knuth,Morris,Pratt共同提出的模式匹配算法,其對于任何模式和目標序列,都可以在線性時間內完成匹配查找,而不會發(fā)生退化,是一個非常優(yōu)秀的模式匹配算法。
分析:KMP模板題、KMP的關鍵是求出next的值、先預處理出next的值、然后一遍掃過、復雜度O(m+n)
實例代碼:
#include<stdio.h>
#include<string.h>
#define N 1000005
int s[N];
int p[N];
int next[N];
int m,n;
void getnext(){
int j=0,k=-1;
next[0]=-1;
while(j<m){
if(k==-1||p[j]==p[k]){
j++;
k++;
next[j]=k;
}
else
k=next[k];
}
}
int kmp(){
int i=0,j=0;
getnext();
while(i<n){
if(j==-1||s[i]==p[j]){
i++;
j++;
}
else
j=next[j];
if(j==m)
return i;
}
return -1;
}
int main(){
int t;
scanf("%d",&t);
while(t--){
scanf("%d%d",&n,&m);
for(int i=0;i<n;i++)
scanf("%d",&s[i]);
for(int i=0;i<m;i++)
scanf("%d",&p[i]);
if(kmp()==-1)
printf("-1\n");
else
printf("%d\n",kmp()-m+1);
}
return 0;
}
以上就是KMP 算法的實例詳解本站關于數據結構和算法的文章還有很多,希望大家搜索查閱,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
上一篇:淺談C++ Socket編程
欄 目:C語言
下一篇:C語言實現2048游戲
本文標題:KMP 算法實例詳解
本文地址:http://www.jygsgssxh.com/a1/Cyuyan/1313.html
您可能感興趣的文章
- 01-10使用C++實現全排列算法的方法詳解
- 01-10深入第K大數問題以及算法概要的詳解
- 01-10深入N皇后問題的兩個最高效算法的詳解
- 01-10用C++實現DBSCAN聚類算法
- 01-10深入全排列算法及其實現方法
- 01-10全排列算法的非遞歸實現與遞歸實現的方法(C++)
- 01-10貪心算法 WOODEN STICKS 實例代碼
- 01-10輸出1000以內的素數的算法(實例代碼)
- 01-10使用map實現單詞轉換的實例分析
- 01-10快速模式匹配算法(KMP)的深入理解


閱讀排行
本欄相關
- 04-02c語言函數調用后清空內存 c語言調用
- 04-02func函數+在C語言 func函數在c語言中
- 04-02c語言的正則匹配函數 c語言正則表達
- 04-02c語言用函數寫分段 用c語言表示分段
- 04-02c語言中對數函數的表達式 c語言中對
- 04-02c語言編寫函數冒泡排序 c語言冒泡排
- 04-02c語言沒有round函數 round c語言
- 04-02c語言分段函數怎么求 用c語言求分段
- 04-02C語言中怎么打出三角函數 c語言中怎
- 04-02c語言調用函數求fibo C語言調用函數求
隨機閱讀
- 08-05dedecms(織夢)副欄目數量限制代碼修改
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 01-10SublimeText編譯C開發(fā)環(huán)境設置
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 01-11ajax實現頁面的局部加載
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 01-10delphi制作wav文件的方法
- 01-10C#中split用法實例總結
- 04-02jquery與jsp,用jquery


