java sunday算法_Sunday算法:最快的字符串匹配算法

之前被KMP的next数组搞的头昏脑胀说不上也是比较烦人的,今天看到还有这么有趣而且高效的算法(比KMP还快),看来有必要做一点笔记了

Sunday算法是Daniel M.Sunday于1990年提出的字符串模式匹配算法,其简单、快速的特点非常好!

思路

其核心思想是:在匹配过程中,模式串发现不匹配时,算法能跳过尽可能多的字符以进行下一步的匹配,从而提高了匹配效率;可以预见到,“跳过多个数”这个逻辑又可以写一个方法,然后被主函数调用

如果该字符没有在匹配串中出现则直接跳过,即移动步长= 匹配串长度+1;否则,同BM算法一样其移动步长=匹配串中最右端的该字符到末尾的距离+1

16467b2bda76ed3d3f7f374277cdffff.png

每一次移动前决定移动步长的是模式串末尾的下一个位置对应的主串字符

实现

//C语言

#include

#include

int getCurlA(char *tar, char ch, int curlA)

{

int *p = tar;

int delta = 0;

while(p && *p!=ch){

p++;

delta + = 1;

}

return curlA - delta;

}

int SundaySearch(char *src, char *tar)

{

int srcLen = strlen(src);

int tarLen = strlen(tar);

int curlA = curlB = 0;

while(src[curlA] == tar[curlB]){

if(curlB == tarLen-1){

return curlB - tarLen + 1;

}else{

curlA = getCurlB(&tar, src[curlA], curlB+1);

}

curlA++;

}

return -1;

}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值