常见的字符串匹配算法有BF、KMP(教科书中非常经典的)、BM、Sunday算法

这里主要想介绍下性能比较好并且实现比较简单的Sunday算法 。

基本原理:

从前往后匹配,如果遇到不匹配情况判断母串参与匹配的最后一位的下一位字符

,如果该字符出现在模板串中,选择最右出现的位置进行对齐;

否则直接跳过该匹配区域。

画图说明:

首先下标为0 的字符相互比较,发现并不相等,

然后查找 s 中参与匹配的最后一位字符的下一字符 ,即 i ,  看 i 在是不是在t中(从右向左匹配) 发现i不在t中,

接下来 s后移2(即t.length())位,到i处,发现i不存在于t中,于是 s后移2(即t.length())位,到x处 发现x存在于t中

于是s在移动(t.length()-x在t中出现的下标) 在做比较

代码演示:

 

public class SundaySearch {

	public static void main(String[] args) {
String s = "thiexaamp";
String t = "ex";
int rtn = sundaySearch(s, t);
System.out.println(rtn);
}
/**
* source 母串
* target 模板串
* 返回值 如果存在就返回target的第一个字符在source的下标
*
*/
private static int sundaySearch(String source, String target) {
int loc = 0;
int locSource = 0;
int locTarget = 0;
int count = 0; //用于记录有几个字符相同,如果与locTarget的长度相等就找到了 while (locSource < source.length() && locTarget < target.length()) {
if (target.charAt(locTarget) == source.charAt(locSource)) {
locTarget++;
locSource++;
count++;
} else {
count = 0;
if (locSource < source.length() - target.length()) {
//看原下标+target.length()位的元素是不是在target中,(从右往左匹配)
loc = target.lastIndexOf(source.charAt(locSource + target.length()));
} else {
break;
}
if (loc == -1) {//不存在 locSource 移动target.length()位
locSource = locSource + target.length();
} else {
//存在,右移(target.length() - loc) 位
locSource = locSource + target.length() - loc;
}
locTarget = 0;
}
}
if (loc != -1 && count == target.length()) {
return locSource - count;
}
return -1;
}
}

  运行结果如下

字符串匹配 - sunday算法的更多相关文章

  1. 通用高效字符串匹配--Sunday算法

    字符串匹配(查找)算法是一类重要的字符串算法(String Algorithm).有两个字符串, 长度为m的haystack(查找串)和长度为n的needle(模式串), 它们构造自同一个有限的字母表 ...

  2. 字符串匹配KMP算法详解

    1. 引言 以前看过很多次KMP算法,一直觉得很有用,但都没有搞明白,一方面是网上很少有比较详细的通俗易懂的讲解,另一方面也怪自己没有沉下心来研究.最近在leetcode上又遇见字符串匹配的题目,以此 ...

  3. 字符串匹配Boyer-Moore算法:文本编辑器中的查找功能是如何实现的?---这应该讲的最容易懂的文章了!

    关于字符串匹配算法有很多,之前我有讲过一篇 KMP 匹配算法:图解字符串匹配 KMP 算法,不懂 kmp 的建议看下,写的还不错,这个算法虽然很牛逼,但在实际中用的并不是特别多.至于选择哪一种字符串匹 ...

  4. 字符串匹配常见算法(BF,RK,KMP,BM,Sunday)

    今日了解了一下字符串匹配的各种方法. 并对sundaysearch算法实现并且单元. 字符串匹配算法,是在实际工程中经常遇到的问题,也是各大公司笔试面试的常考题目.此算法通常输入为原字符串(strin ...

  5. 字符串匹配--Karp-Rabin算法

    主要特征 1.使用hash函数 2.预处理阶段时间复杂度O(m),常量空间 3.查找阶段时间复杂度O(mn) 4.期望运行时间:O(n+m) 本文地址:http://www.cnblogs.com/a ...

  6. 字符串匹配KMP算法

    1. 字符串匹配的KMP算法 2. KMP算法详解 3. 从头到尾彻底理解KMP

  7. 字符串匹配--kmp算法原理整理

    kmp算法原理:求出P0···Pi的最大相同前后缀长度k: 字符串匹配是计算机的基本任务之一.举例,字符串"BBC ABCDAB ABCDABCDABDE",里面是否包含另一个字符 ...

  8. 字符串匹配KMP算法的C语言实现

    字符串匹配是计算机的基本任务之一. 举例来说,有一个字符串"BBC ABCDAB ABCDABCDABDE",我想知道,里面是否包含另一个字符串"ABCDABD" ...

  9. 字符串匹配KMP算法的讲解C++

    转自http://blog.csdn.net/starstar1992/article/details/54913261 也可以参考http://blog.csdn.net/liu940204/art ...

随机推荐

  1. EF CodeFirst学习笔记002--更新数据库表

    BlogEntities这个类从DbContext继承,负责数据库的更新. Database.SetInitializer(new DropCreateDatabaseIfModelChanges&l ...

  2. python学习day6 for循环 字符串的内置方法

    1.for循环 和while相比 l=[1,2,3] i=0 while i <len(l) print(l[i]) i+=1 l=['a','b','c'] for item in l: pr ...

  3. tab template

    <div class="box"> <div class="box-body"> <div class="nav-tab ...

  4. 六 json&pickle模块

    之前我们学习过用eval内置方法可以将一个字符串转成python对象,不过,eval方法是有局限性的,对于普通的数据类型,json.loads和eval都能用,但遇到特殊类型的时候,eval就不管用了 ...

  5. websocket搭建错误

    用一下版本: gevent == 1.2.2 Eel == 0.9.7 gevent-websocket == 0.10.1 greenlet == 0.4.13 PyInstaller == 3.3 ...

  6. 非常棒的轨迹插件Better Trails v1.4.6

    点击下载

  7. Vue Baidu Map 插件的使用

    最近在做一个项目,技术采用的是Vue.js套餐,有个百度地图的需求,当时,大脑宕机,立马去引入百度地图API,当时想到两种方法,一种是在index.html中全局引入js,此法吾不喜,就采用了第二种异 ...

  8. 解决node-pre-gyp install --fallback-to-build 卡住不动

    一般是因为需要下载国外的包,要么连VPN,要么使用淘宝的镜像: 使用cnpm: npm install -g cnpm --registry=https://registry.npm.taobao.o ...

  9. f5创建VS

    1.1) 2) 3) 4) 5) 2.Availability 1)Pool 中的monitor保障服务高可用 2)Pool 失败机制一 Fallback Host 最后的host( 使用于HTTP ...

  10. f5时间设置

    方法一:NTP(推荐) 注:修改ntp server后大约需要10分钟左右才能同步成功. 查看ntp状态: 方法二:手动修改