kmp模版

Posted Angel_Kitty

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了kmp模版相关的知识,希望对你有一定的参考价值。

 1 int kmpnext[N];
 2 char s[N],t[N];///s为主串,t为模式串
 3 int slen,tlen;///slen为主串的长度,tlen为模式串的长度
 4 void getnext()
 5 {
 6     int i,j;
 7     j=next[0]=-1;
 8     i=0;
 9     while(i<tlen)
10     {
11         if(j==-1||x[i]==x[j])
12         {
13             kmpnext[++i]=++j;
14         }
15         else
16         {
17             j=kmpnext[j];
18         }
19     }
20 }
21 /*
22 返回模式串T在主串S中首次出现的位置
23 返回的位置是从0开始的。
24 */
25 int kmp_index()
26 {
27     int i=0,j=0;
28     getnext();
29     while(i<slen&&j<tlen)
30     {
31         if(j==-1||s[i]==t[j])
32         {
33             i++;
34             j++;
35         }
36         else
37             j=kmpnext[j];
38     }
39     if(j==tlen)
40         return i-tlen;
41     else
42         return -1;
43 }
44 /*
45 返回模式串在主串S中出现的次数
46 */
47 int kmp_count()
48 {
49     int ans=0;
50     int i,j=0;
51     if(slen==1&&tlen==1)
52     {
53         if(s[0]==t[0])
54             return 1;
55         else
56             return 0;
57     }
58     getnext();
59     for(i=0;i<slen;i++)
60     {
61         while(j>0&&s[i]!=t[j])
62             j=kmpnext[j];
63         if(s[i]==t[j])
64             j++;
65         if(j==tlen)
66         {
67             ans++;
68             j=kmpnext[j];
69         }
70     }
71     return ans;
72 }

 

以上是关于kmp模版的主要内容,如果未能解决你的问题,请参考以下文章

马拉车——模版+KMP——模版

kmp模版

使用Visual Studio Code自定义代码模版

使用 Git 来管理 Xcode 中的代码片段

poj 2752 Seek the Name, Seek the Fame (KMP纯模版)

KMP算法,这是我看到的最简单的最好理解的KMP算法