| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1002 人关注过本帖
标题:请教一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
快速回复:请教一KMP算法的问题
数据加载中...
 
   



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

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