首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >kmp模版

kmp模版

作者头像
Angel_Kitty
发布2018-04-09 14:51:55
1.7K0
发布2018-04-09 14:51:55
举报
 1 int kmpnext[N];
 2 char s[N],t[N];///s为主串,t为模式串
 3 int slen,tlen;///slen为主串的长度,tlen为模式串的长度
 4 inline void getnext()
 5 {
 6     int i,j;
 7     j=kmpnext[0]=-1;
 8     i=0;
 9     while(i<tlen)
10     {
11         if(j==-1||t[i]==t[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 inline 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 inline 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 }
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2017-07-01 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档