| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 906 人关注过本帖
标题:KMP算法
取消只看楼主 加入收藏
kingwyf87
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2006-12-6
收藏
 问题点数:0 回复次数:0 
KMP算法

Description

按照改进KMP算法计算指定模式串的nextval向量。

Input

一组由字母和数字组成的模式串,每个模式串输入一行,长度不小于1,不大于200。

Output

输入每个模式串的nextval向量,每个nextval向量输出一行,各数值之间用一个空格隔开。

Sample Input

aabb
abcabc

Sample Output

-1 -1 1 0
-1 0 0 -1 0 0


哪位高手帮我改一下阿 谢谢~~
#include<iostream>
#include<conio.h>
#include<string>
using namespace std;
int Getnextval(char *T,int *nextval)
{ int i=0,k=-1;
nextval[0]=-1;
while(i<strlen(T))
{
if(k==-1||T[i]==T[k])
{
i++;k++;
if(T[i]!=T[k]) nextval[i]=k;
else nextval[i]=nextval[k];
}

else k=nextval[k];
}
return 1;
}
int main()
{
char S[200];
int next[200],n,m=0;
while(gets(S)!='\0')
{
Getnextval(S,next);
for(n=0;n<strlen(S);n++)
cout<<next[n]<<" ";
cout<<endl;
}
getch();
return 0;
}

搜索更多相关主题的帖子: KMP 算法 
2006-12-06 22:15
快速回复:KMP算法
数据加载中...
 
   



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

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