| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 787 人关注过本帖
标题:求KMP算法的实现C或C++程序与KMP算法中求NEXT【】的C或C++程序
只看楼主 加入收藏
艹蛋灬爱情
Rank: 1
等 级:新手上路
帖 子:6
专家分:0
注 册:2011-10-21
结帖率:0
收藏
已结贴  问题点数:20 回复次数:6 
求KMP算法的实现C或C++程序与KMP算法中求NEXT【】的C或C++程序
求KMP算法的实现C或C++程序与KMP算法中求NEXT【】的C或C++程序,求高手帮忙,先谢谢啦
搜索更多相关主题的帖子: 算法 
2011-10-21 16:57
jj369258
Rank: 4
等 级:业余侠客
帖 子:116
专家分:226
注 册:2010-12-2
收藏
得分:10 
#include<stdio.h>
#include<string.h>
#define NOTFOUND -1
#define ERROR -2
#define MAXLEN 100  
char S[MAXLEN+10],T[MAXLEN+10],st[MAXLEN+10];   
int S0,T0;                                      
int pos;                                       
int next[MAXLEN+10];
void Init(char *S,int &S0)
{
    int len,i;
    New_Input:
    scanf("%s",st);
    len=strlen(st);
    if (len>MAXLEN)
    {
        printf("This String is too long,Please Input a new one.\n\n");
        goto New_Input;
    }
    for (i=1;i<=len;i++) S[i]=st[i-1];
    S[len+1]='\0';
    S0=len;
}

void Get_next(char *S,int *next)
{
    int i=1,j=0;
    next[1]=0;
    while (i<T0)
        if (j==0 || T[i]==T[j])
        {i++; j++; next[i]=next[j];}
        else j=next[j];
}

int Index_KMP(char *S,char *T,int pos)
{

    int i=pos,j=1;
    while (i<=S0 && j<=T0)
        if (j==0 || S[i]==T[j])
        {i++; j++;}
        else j=next[j];
    if (j>T0) return i-T0;
   else return NOTFOUND;
}
int main()
{
    int ret;//函数返回值
    Init(S,S0);
    Init(T,T0);
    scanf("%d",&pos);
    Get_next(T,next);
    ret=Index_KMP(S,T,pos);
    if (ret==NOTFOUND) printf("Not Found.\n");
    else if (ret==ERROR) printf("The Input Data is Error.\n");
    else printf("In S,from %dth is equal to T.\n",ret);
    return 0;

}
2011-10-22 14:39
艹蛋灬爱情
Rank: 1
等 级:新手上路
帖 子:6
专家分:0
注 册:2011-10-21
收藏
得分:0 
求next的值的程序呢?
2011-10-25 13:17
艹蛋灬爱情
Rank: 1
等 级:新手上路
帖 子:6
专家分:0
注 册:2011-10-21
收藏
得分:0 
回复 3楼 艹蛋灬爱情
求next的值的程序,要求有输出next的值在屏幕上输出的哦
2011-10-25 13:46
藏收收藏!
Rank: 2
等 级:论坛游民
帖 子:3
专家分:10
注 册:2011-10-26
收藏
得分:10 
多谢楼主啊!!
我也沾光啦!
这个也烦了我好几天啊!
2011-10-26 20:45
艹蛋灬爱情
Rank: 1
等 级:新手上路
帖 子:6
专家分:0
注 册:2011-10-21
收藏
得分:0 
回复 5楼 藏收收藏!
wo 我的问题还没解决呢!!
2011-10-29 00:29
caikun1986
Rank: 2
等 级:论坛游民
帖 子:4
专家分:13
注 册:2010-11-25
收藏
得分:0 
上面是正常的KMP算法,求next改进版本
void Get_next(char *S,int *next)
{
    int i=1,j=0;
    next[1]=0;
    while (i<T0)
        if (j==0 || T[i]==T[j])
        {
            i++;
            j++;
            if (T[i] == T[j])
                next[i]=next[j];
            else
                next[i] = j;
        }
        else j=next[j];
}
2011-10-29 09:31
快速回复:求KMP算法的实现C或C++程序与KMP算法中求NEXT【】的C或C++程序
数据加载中...
 
   



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

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