| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 462 人关注过本帖
标题:KMP算法,结果得不出来
只看楼主 加入收藏
小J
Rank: 8Rank: 8
等 级:等待验证会员
威 望:1
帖 子:282
专家分:704
注 册:2009-6-18
结帖率:100%
收藏
 问题点数:0 回复次数:0 
KMP算法,结果得不出来
#include "stdio.h"
#include "string.h"
void GetPreNext(char *s,int *next)
{
    int i,j,length;
    length=strlen(s);
    j=0;
    i=1;
    next[1]=0;
    while(i<=length)
    {
        if(j==0||s[i]==s[j])
        {
            i++;
            j++;
            if(s[i]!=s[j])
            {
                next[i]=j;
            }
            else
            {
                next[i]=next[j];
            }
        }
        else
        {
            j=next[j];
        }
    }
}
int math(char *s,char *t,int *next)
{
    int length_s,length_t;
    int i,j;
    i = 1;
    j = 1;
    length_s = strlen(s);
    length_t = strlen(t);
    if(length_s < length_t)
    {
        return -1;
    }
    else
    {
        while(i <= length_s && j <= length_t)
        {
            if(j==0||s[i]==t[j])
            {
                i++;
                j++;
            }
            else
            {
                j=next[j];
            }
        }
        if(j>length_t)
        {
            return i-j+1;
        }
        else
        {
            return -1;
        }
    }
}
void main()
{
    char s[100]="zhonghuarenminggongheguo";
    char t[100]="ing";
    int next[100]={0},n;
    GetPreNext(t,next);
    n=math(s,t,next);
    if(n==-1)
    {
        printf("Cannot find the string!\n");
    }
    else
    {
        printf("The position is %d\n",n);
    }
}
当字符串比较短的时候能查的出来,当字符串比较长的时候查不出来。请高手帮忙改下!

[ 本帖最后由 小J 于 2010-3-24 17:43 编辑 ]
搜索更多相关主题的帖子: KMP 算法 结果 
2010-03-24 17:23
快速回复:KMP算法,结果得不出来
数据加载中...
 
   



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

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