KMP初探
最近在做字符串匹配,沉迷于indexof无法自拔,但是考虑到大数据处理的时间复杂度,决定研究一波KMP。
在这我就不讲什么原理了,转自: https://www.cnblogs.com/zhangtianq/p/5839909.html
String a = "BBC ABCDAB ABCDABCDABDE";
String b = "ABCDABD";
char [] alist = a.toCharArray();
char [] blist = b.toCharArray();
int [] next = new int[b.length()]; //next数组的生成
//next数组是KMP中比较难以理解的,实际就是求对应目标串的最长相同前后缀
//如ABCDAB中AB就是最长的前后缀,又如ABCDA中A就是最长的前后缀
int k = -1;
int j = 0;
next[0] = -1;
while(j < b.length()-1){
if (k == -1 || blist[k] == blist[j]) {
++k;
++j;
next[j] = k;
}else {
k = next[k];
}
} //a,b两个字符串匹配
int i = 0;
j = 0;
while(i<a.length() && j<b.length()){
if (j == -1 || alist[i] == blist[j]) {
i++;
j++;
}else{
j = next[j];
}
}
if (j == b.length()) {
System.out.println(i-j);
}else {
System.out.println(-1);
}
KMP初探的更多相关文章
- KMP初探·总结
		
昨天自己乱搞了一天kmp之后终于弄懂了kmp 的基本原理. 早上看见了好多只讲原理和数学公式推导的博客,感觉很坑,无法理解.后来找到了一篇图文并茂的博客,感觉很快就理解了. KMP的精髓在于n ...
 - 初探KMP算法
		
数据结构上老师也没讲这个,平常ACM比赛时我也没怎么理解,只是背会了代码--前天在博客园上看见了一篇介绍KMP的,不经意间就勾起了我的回忆,写下来吧,记得更牢. 一.理论准备 ...
 - KMP算法初探
		
[edit by xingoo] kmp算法其实就是一种改进的字符串匹配算法.复杂度可以达到O(n+m),n是参考字符串长度,m是匹配字符串长度. 传统的算法,就是匹配字符串与参考字符串挨个比较,如果 ...
 - 初探—KMP模式匹配算法
		
KMP算法思想: 普通的字符串匹配算法S主串必须要回溯.但回溯就影响了效率. 改进的地方也就是这里,我们从P 串本身出发,事先就找准了T自身前后部分匹配的位置,那就可以改进算法. next数组的含义: ...
 - KMP算法求解
		
// KMP.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include<iostream> using namespac ...
 - 简单有效的kmp算法
		
以前看过kmp算法,当时接触后总感觉好深奥啊,抱着数据结构的数啃了一中午,最终才大致看懂,后来提起kmp也只剩下“奥,它是做模式匹配的”这点干货.最近有空,翻出来算法导论看看,原来就是这么简单(先不说 ...
 - 初探领域驱动设计(2)Repository在DDD中的应用
		
概述 上一篇我们算是粗略的介绍了一下DDD,我们提到了实体.值类型和领域服务,也稍微讲到了DDD中的分层结构.但这只能算是一个很简单的介绍,并且我们在上篇的末尾还留下了一些问题,其中大家讨论比较多的, ...
 - CSharpGL(8)使用3D纹理渲染体数据 (Volume Rendering) 初探
		
CSharpGL(8)使用3D纹理渲染体数据 (Volume Rendering) 初探 2016-08-13 由于CSharpGL一直在更新,现在这个教程已经不适用最新的代码了.CSharpGL源码 ...
 - 从273二手车的M站点初探js模块化编程
		
前言 这几天在看273M站点时被他们的页面交互方式所吸引,他们的首页是采用三次加载+分页的方式.也就说分为大分页和小分页两种交互.大分页就是通过分页按钮来操作,小分页是通过下拉(向下滑动)时异步加载数 ...
 
随机推荐
- 小白学flask之静态文件
			
引入css的方式有两种 1 那在flask中,如何处理静态文件? 做法很简单,只要在你的包或模块旁边创建一个名为 static 的文件夹就行了. flask的静态文件是位于应用的 /static 中的
 - javascript图片预加载
			
图片预加载是非常常见的一个功能,PC和移动端都会用到,尤其是在移动端,只要涉及到较多图片的加载都会用到该技术.下面是移动端用到的,引入了zepto. <!DOCTYPE html> < ...
 - jquery插件一直报错:xx is not a function
			
当然像js文件未引用或者js插件使用方法不对这样的解决办法想必大家都已经试过了. 那么在放弃前请最后看一下是不是引用了两个jquery文件. 引用了两个jquery文件! 引用了两个jquery文件! ...
 - cnpm 安装
			
国内npm 安装比较慢,可选择cnpm npm install -g cnpm --registry=https://registry.npm.taobao.org
 - string 替换字符串
			
C++的string提供了replace方法来实现字符串的替换,但是对于将字符串中某个字符串全部替换这个功能,string并没有实现,我们今天来做的就是这件事.首先明白一个概念,即string替换所有 ...
 - mysql 更新sql报错:You can't specify target table 'wms_cabinet_form' for update in FROM clause
			
数据库里面有两个字段的位置不对,要把他们对调换下.因为没有数据库写的权限,需要用sql语句来实现.原来以为简单的 update table a set a.字段a=(select b字段 from t ...
 - Nginx(持续更新中)
			
Nginx介绍 -- 安装部署 -- 配置文件说明 --
 - php模拟post提交
			
<?php $url = "xxxxx"; // 用户名 $loginName = ''; // 密码 $pwd = ''; // service $serviceName ...
 - Congestion Avoidance in TCP
			
Congestion Avoidance in TCP Consequence of lack of congestion control When a popular resource is sha ...
 - IEEP部署企业级网络工程-网络故障-环路故障
			
网络故障 1.环路故障 概念 1).以太网是一个支持广播的网络, 在没有环路的环境中,广播报文在网络中以泛洪的形式被送达到网络的第一个角落,以保证每个设备都能够接受到它.每台二层设备在接收到广播报文以 ...