| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 284 人关注过本帖
标题:kmp的字符串的查找运行结果不对,求修改
只看楼主 加入收藏
惜缘0310
Rank: 1
等 级:新手上路
帖 子:5
专家分:0
注 册:2012-11-17
结帖率:50%
收藏
已结贴  问题点数:20 回复次数:1 
kmp的字符串的查找运行结果不对,求修改
/* Note:Your choice is C IDE */
#include "stdio.h"
#include "string.h"
#define maxsize 100
struct string
{
    char str[maxsize];
    int length;
};
int str_len(struct string *a)
{
    int i;
    for(i=1;a->str[i]!='\0';i++);
    return(i);
}
get_next(struct string a,int next[])
{
    int j,k;
    j=1,k=0;
    next[1]=0;
    while(j<a.length)
    {
        if(k==0||a.str[j]==a.str[k])
       {j++;k++;next[j]=k;}
       else{k=next[k];}
       }
    }
int chazhao(struct string a,struct string b,int next[])
{ int i,j;
    i=1,j=1;
    while(i<=a.length&&j<=b.length)
    {
        if(a.str[i]==b.str[j])
        {i++;j++;}
        else j=next[j];
    }
    if(j>=b.length)
        return(i-b.length);
     else
        return(-1);      
 }
main()
{   
    struct string a,b;
    int next[maxsize],k;
    gets( a.str);
    a.length=str_len( &a);
    gets( b.str);
    b.length=str_len( &b);
   
    k=chazhao(a,b,next);
    if(k==-1)
    printf("不存在");
    else
    {
        printf("存在");
        printf("从%d个字符开始",k);

    }
}
搜索更多相关主题的帖子: next include return 字符串 
2012-11-17 23:56
寒风中的细雨
Rank: 17Rank: 17Rank: 17Rank: 17Rank: 17
等 级:贵宾
威 望:66
帖 子:1710
专家分:8645
注 册:2009-9-15
收藏
得分:20 
建议:在本版搜索KMP关键字   一大把可以供LZ参考的
2012-11-18 11:07
快速回复:kmp的字符串的查找运行结果不对,求修改
数据加载中...
 
   



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

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