网页
资讯
视频
图片
知道
文库
贴吧
地图
采购
进入贴吧
全吧搜索
吧内搜索
搜贴
搜人
进吧
搜标签
日
一
二
三
四
五
六
签到排名:今日本吧第
个签到,
本吧因你更精彩,明天继续来努力!
本吧签到人数:0
一键签到
成为超级会员,使用一键签到
一键签到
本月漏签
0
次!
0
成为超级会员,赠送8张补签卡
如何使用?
点击日历上漏签日期,即可进行
补签
。
连续签到:
天 累计签到:
天
0
超级会员单次开通12个月以上,赠送连续签到卡3张
使用连续签到卡
03月22日
漏签
0
天
c语言吧
关注:
798,934
贴子:
4,351,363
看贴
图片
吧主推荐
视频
游戏
3
回复贴,共
1
页
<<返回c语言吧
>0< 加载中...
关于串的next值,和KNP匹配函数,求大神指教
只看楼主
收藏
回复
有梦Ooo
酱油
4
该楼层疑似违规已被系统折叠
隐藏此楼
查看此楼
next函数是用来干嘛的?kmp匹配函数又是用来干嘛的啊?
看到一个代码,是求一篇文章某个固定单词出现的次数和出现的所在行和列
大一刚学数据结构,遇到了此问题,求好心人帮忙
有梦Ooo
酱油
4
该楼层疑似违规已被系统折叠
隐藏此楼
查看此楼
//2. KMP匹配函数
int Index(SString S,SString T,int pos)
{ // 利用模式串T的next函数求T在主串S中第pos个字符之后的位置的KMP算法
// 其中T非空,1 pos StrLength(s)
int i=pos,j=1;
while
(i<=S[0]&&j<=T[0])
{
if
(j==0||S[i]==T[j]) {++i;++j;} // 继续比较后继字符
else
j=next[j]; // 模式串向右移动
}
if
(j>T[0]) return (i-T[0]); // 匹配成功
else return
0; // 匹配失败
}
ba_ab_ba
帕秋莉糕
12
该楼层疑似违规已被系统折叠
隐藏此楼
查看此楼
kmp算法的优点就是不用回溯,next会告诉你当一次匹配失败,下次该从该子串的哪个位置开始匹配,建议自己在纸上画一遍运行过程,就懂了。。。
登录百度账号
扫二维码下载贴吧客户端
下载贴吧APP
看高清直播、视频!
贴吧页面意见反馈
违规贴吧举报反馈通道
贴吧违规信息处理公示