标题:KMP算法 关于求next[]
只看楼主
木头lbj
Rank: 7Rank: 7Rank: 7
来 自:黄山
等 级:黑侠
威 望:1
帖 子:269
专家分:527
注 册:2010-11-6
结帖率:100%
已结贴  问题点数:20 回复次数:8 
KMP算法 关于求next[]
对kmp算法真心弄不明白。。。下面是我自己写的算法的实现,不能成功运行。。。。求指教。。。关键是在于对next[]的引用上。。。写的很乱。。。
程序代码:
#include <stdio.h>
#define M 100

int GetNext(char *t,int next[]);
int StrIndex_KMP(char *s,char *t);

int main()
{
    char s[M];
    char t[M];
    printf("请输入目标串:\n");
    gets(s);
    printf("请输入模式串:\n");
    gets(t);
    StrIndex_KMP(s,t);
}

int GetNext(char *t,int next[])
{
    int i = 0, j = 0;
    next[1] = 0;
    while(i < strlen(t))
    {
        if(j == 0 || t[i] == t[j])
        {
            ++ i;
            ++ j;
            next[i] = j;
            return next[i];
        }
        else
        j = next[j];
        return j;
    }
}

int StrIndex_KMP(char *s,char *t)
{
    int i = 2,j = 1;
    int next[M];
    while(i <= strlen(s) && j <= strlen(t))
        if(j == 0 || s[i] == t[j])
            {
            i ++;
            j ++;
            }
            else
            j = GetNext(t,next);
            if(j > strlen(t))
            printf("匹配成功!位置为%d\n",i - strlen(t)+1);
            else
            printf("匹配失败!\n");
  
    return 0;
}

搜索更多相关主题的帖子: 成功 
2011-05-29 21:59
寒风中的细雨
Rank: 17Rank: 17Rank: 17Rank: 17Rank: 17
等 级:贵宾
威 望:66
帖 子:1710
专家分:8645
注 册:2009-9-15
得分:20 
程序代码:
#include <stdio.h>
#include <string.h>

#define NEXT_SIZE 20

unsigned short next[NEXT_SIZE] = {0};
char t[NEXT_SIZE] = {0};

void get_next(const unsigned int size)
{
    unsigned int i=1;//
    unsigned int j=0;//

    next[1] = 0;

    while (i < size)
    {
        if (j==0 && t[i]!=t[j])
        {
            ++i;
            next[i] = j;
        }
        else if (t[i] == t[j])
        {
            ++j;
            ++i;
            next[i] = j;
        }
        else
        {
            j = next[j];
        }
    }

}
void show_next(const unsigned int size)
{
    unsigned int temp = 1;

    printf("模式串对应下标值\n");
    while (size > temp)
    {
        printf("%u ", next[temp]);
        ++temp;
    }
    printf("\n");
}

int main(void)
{
    printf("请输入模式串:");
    gets(t);

    get_next(strlen(t));
    show_next(strlen(t));

    return 0;
}
2011-05-30 20:43
寒风中的细雨
Rank: 17Rank: 17Rank: 17Rank: 17Rank: 17
等 级:贵宾
威 望:66
帖 子:1710
专家分:8645
注 册:2009-9-15
得分:0 
2011-05-30 20:44
寒风中的细雨
Rank: 17Rank: 17Rank: 17Rank: 17Rank: 17
等 级:贵宾
威 望:66
帖 子:1710
专家分:8645
注 册:2009-9-15
得分:0 
看看应该可以看懂
    while (i < size)
    {
        if (j==0 && t[i]!=t[j])
        {
            ++i;
            next[i] = j;
        }
        else if (t[i] == t[j])
        {
            ++j;
            ++i;
            next[i] = j;
        }
        else
        {
            j = next[j];
        }
    }
这样写目前认为比较合理的  
还有不明白 再来
2011-05-30 20:55
木头lbj
Rank: 7Rank: 7Rank: 7
来 自:黄山
等 级:黑侠
威 望:1
帖 子:269
专家分:527
注 册:2010-11-6
得分:0 
回复 3楼 寒风中的细雨
我觉得
程序代码:
if(j == 0 || t[i] == t[j])
        {
            ++ i;
            ++ j;
            next[i] = j;
         }
程序代码:
if (j==0 && t[i]!=t[j])
        {
            ++i;
            next[i] = j;
        }
        else if (t[i] == t[j])
        {
            ++j;
            ++i;
            next[i] = j;
        }

的效果应该是相同的吧。。。
对求next[j]还是略懂的。我想知道怎么在KMP算法的实现中调用next[j],我写的实现代码不行。。。。应该是在调用next[j]的地方出错了。。。

。。。!!!)))000
2011-05-30 22:30
寒风中的细雨
Rank: 17Rank: 17Rank: 17Rank: 17Rank: 17
等 级:贵宾
威 望:66
帖 子:1710
专家分:8645
注 册:2009-9-15
得分:0 
回复 5楼 木头lbj
程序代码:
#include <stdio.h>
#include <string.h>

#define NEXT_SIZE 20

unsigned short next[NEXT_SIZE] = {0};
char t[NEXT_SIZE] = {0};
char s[40] = {0};

void get_next(const unsigned int size)
{
    unsigned int i=1;//
    unsigned int j=0;//

    next[1] = 0;

    while (i < size)
    {
        if (j==0 && t[i]!=t[j])
        {
            ++i;
            next[i] = j;
        }
        else if (t[i] == t[j])
        {
            ++j;
            ++i;
            next[i] = j;
        }
        else
        {
            j = next[j];
        }
    }

}
void show_next(const unsigned int size)
{
    unsigned int temp = 1;

    printf("模式串对应下标值\n");
    while (size > temp)
    {
        printf("%u ", next[temp]);
        ++temp;
    }
    printf("\n");
}
void kmp(const unsigned int s_size, const unsigned int t_size)
{
    unsigned int i=0, j=0;

    if (s_size < t_size)
    {
        printf("匹配失败!\n");
        return;
    }
   
    while (i < s_size && j < t_size)
    {
        if (j==0 && s[i]!=t[j])
        {
            ++i;
        }
        else if (s[i] == t[j])
        {
            ++j;
            ++i;
        }
        else
        {
            j = next[j];
        }
    }

    if (j == t_size)
    {
        printf("匹配成功!位置为%d\n", i+1-t_size);
    }
    else
    {
        printf("匹配失败!\n");
    }
}


int main(void)
{
    printf("请输入目标串:\n");
    gets(s);
    printf("请输入模式串:");
    gets(t);

    get_next(strlen(t));

 //   show_next(strlen(t));
    kmp(strlen(s), strlen(t));

    return 0;
}
2011-05-31 08:12
寒风中的细雨
Rank: 17Rank: 17Rank: 17Rank: 17Rank: 17
等 级:贵宾
威 望:66
帖 子:1710
专家分:8645
注 册:2009-9-15
得分:0 
自己所得出的next值的下标是从什么值开始是有效的自己要清楚

就6楼的程序来说  next直接使用的是和字符数组的下标相同的值  也就是说 是从0到它的长度减1下标一一对应的

不过next[0]是没有意义的  
2011-05-31 08:18
木头lbj
Rank: 7Rank: 7Rank: 7
来 自:黄山
等 级:黑侠
威 望:1
帖 子:269
专家分:527
注 册:2010-11-6
得分:0 
谢谢啊。。。。我来继续研究下的

。。。!!!)))000
2011-05-31 12:43
古城荆棘王
Rank: 1
等 级:新手上路
帖 子:14
专家分:0
注 册:2011-9-20
得分:0 
这个 比如说我们输入 we are we 匹配子串:we 怎样才能出现两次
2012-05-29 13:57



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-341371-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 1.488954 second(s), 9 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved