标题:请教一KMP算法的问题
只看楼主
leon57
Rank: 1
来 自:xznu
等 级:新手上路
帖 子:29
专家分:0
注 册:2008-7-19
 问题点数:0 回复次数:1 
请教一KMP算法的问题
int Index_KMP(HString &S,HString &T,int pos)
{
    i=pos;
    j=1;
    while(i<=S.len&&j<=T.len)
    {
        if(S.ch[i]==T.ch[j])
        {
            ++i;
            ++j;
        }
        else j=next[j];
    }
    if(j>T.len) return i-T.len;
    else return 0;
}

里面的next[j]怎么编写?
搜索更多相关主题的帖子: KMP 算法 
2008-10-25 21:49
惜缘0310
Rank: 1
等 级:新手上路
帖 子:5
专家分:0
注 册:2012-11-17
得分:0 
get_next(struct string T,int next[])
{
    int j,k;
    j=0,k=-1;
    next[1]=-1;
    while(j<T.length)
    {
        if(k==-1||T.str[j]==T.str[k])
       {j++;k++;next[j]=k;}
       else{k=next[k];}
       }
    }
2012-11-18 21:58



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




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

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