Kmp 算法模板 C

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
/**
 * name:KMP
 * time:2012-11-22
 * 字符串快速匹配
 */
#include<stdio.h>
#include<string.h>
typedef struct seqstring{
    char string[100];
    int length;
}seqstring;
 
void getnext(seqstring p,int next[]){
    int i,j;
    next[0]=-1;//next[0]放上-1
    i=0;//指向字符串每个字符的指针
    j=-1;
    while(i<p.length){//没有到达结尾的话
        if(j==-1||p.string[i]==p.string[j]){//如果是第一个字符或遇到相同的字符
            i++;j++;next[i]=j;
        }
        else
            j=next[j];
    }
    for(i=0;i<p.length;i++){//输出next[]值
        printf("%d ",next[i]);
    }
}
 
int kmp(seqstring t,seqstring p,int next[]){
    int i,j;
    i=j=0;
    while(i<t.length&&j<p.length){
        if(j==-1||t.string[i]==p.string[j]){
            i++;j++;
        }
        else
            j=next[j];
    }
    if(j==p.length) return i-p.length;
    else return -1;
}
int main(){
    seqstring t,p;
    int next[50];
    printf("please input string t:");
    scanf("%s",t.string);
    t.length=strlen(t.string);
    printf("please input string p:");
    scanf("%s",p.string);
    p.length=strlen(p.string);
 
    getnext(p,next);
    printf("\n%d\n",kmp(t,p,next));
}

  

posted @   JL_Zhou  阅读(265)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
点击右上角即可分享
微信分享提示