鱼C论坛

 找回密码
 立即注册
查看: 5313|回复: 8

[学习笔记] ★ 第三十九讲 KMP算法之实现及优化 |【KMP系列核心】★

[复制链接]
发表于 2017-10-29 09:05:26 | 显示全部楼层 |阅读模式
购买主题 已有 17 人购买  本主题需向作者支付 5 鱼币 才能浏览

本帖被以下淘专辑推荐:

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2017-12-9 10:21:12 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2017-12-9 10:21:32 | 显示全部楼层
#include <stdio.h>
typedef char* String;

void get_next( String T, int *next )
{
        int j = 0;
        int i = 1;
        next[1] = 0;

        while( i < T[0] )
        {
                if( 0 == j || T[i] == T[j] )
                {
                        i++;
                        j++;
                        if( T[i] != T[j] )
                        {
                                next[i] = j;
                        }
                        else
                        {
                                next[i] = next[j];
                        }
                }
                else
                {
                        j = next[j];
                }
        }
}

// 返回子串T在主串S第pos个字符之后的位置
// 若不存在,则返回0
int Index_KMP( String S, String T, int pos )
{
        int i = pos;
        int j = 1;
        int next[255];

        get_next( T, next );
        
        while( i <= S[0] && j <= T[0] )
        {
//增加判断,防止特殊情况发生
                if( 0 == j || S[i] == T[j] )
                {
                        i++;
                        j++;
                }
                else
                {
                        j = next[j];
                }
        }

        if( j > T[0] )
        {
                return i - T[0];
        }
        else
        {
                return 0;
        }
}
int main()
{
        char str[255]="ababaaaba";
        int next[255];
        int i=1;
        str[0]=9;
        get_next(str,next);
        printf("next数组的取值:\n");
        for(i=1;i<10;i++)
        {
                printf("%3d",next[i]);
        }
    putchar('\n');
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-12-9 10:23:04 | 显示全部楼层
这样的结果,很尴尬
QQ截图20171209102149.png
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-2-28 15:25:24 | 显示全部楼层
小牧羊 发表于 2017-12-9 10:23
这样的结果,很尴尬

输入的字符串前面要有一个空格,它作为str [0]存放字符串长度。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-2-28 15:49:42 | 显示全部楼层
小牧羊 发表于 2017-12-9 10:23
这样的结果,很尴尬

输出正确的next数组为:0 1 0 1 0 4 2 1 0
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-2-28 16:01:23 | 显示全部楼层
……
int i = pos;
        int j = 1;
        int next[255];

        get_next( T, next );
……
index_kmp函数这里调用get _next函数,其i、j的值都会改变,为什么不影响后面的i、j呢?还是应该把调用get _next函数放在i、j赋值之前?还是调用的get _next函数中的i、j相对于index _kmp函数是局部变量不会影响主函数的i、j的值?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-2-28 16:18:34 | 显示全部楼层
圣狄雅哥 发表于 2018-2-28 16:01
……
int i = pos;
        int j = 1;

查了一下资料,index_kmp函数中的i、j是局部变量,作用于整个index_kmp函数体内,虽然与被调函数get _next中的i、j同名,但作用域不同,不产生冲突;被调函数get _next中的i、j是只作用于该函数体内的局部变量,不会影响index _kmp函数中定义的i、j。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-6-3 18:10:34 | 显示全部楼层
有KMP算法的源码吗?不是这个求next数组的
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-26 15:01

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表