- 浏览: 30556 次
- 性别:
- 来自: 杭州
文章分类
最新评论
package zl.character.compare;
/**
* 字符串匹配 kmp算法
* KMP算法实质:利用已经遍历得到的匹配信息来辅助后面的匹配过程
* @author bo
*
*/
public class Kmp {
/**
* next[j] = k 代表索引5的元素直接k-1个元素和开头k-1个元素相匹配(next数组表示 当pj元素失配的时候 需要把模式串向右移动到什么位置)
* 即p0...p(k-1) 和 p(j-k)...p(j-1) 相等
* 所以 0 < k < j
* @param list
* @return
*/
private int[] getNext(char[] list) {
int len = list.length;
int[] next = new int[len+1];
next[0] = -1;
int i = 0;
int j = -1; //代表k
System.out.println("netx[0]=-1");
while(i < (len - 1)) {
if(j == -1 || list[i] == list[j]) {
i++;
j++;
/*
* 当pk 和 pj 相等的时候 p(j+1) 如果不相等 需要移动到p(k+1)上
* 但是,如果p(j+1) = p(k+1) 即使移动也是陪同同一个字符 所以把p(j+1)不匹配问题转移到p(k+1)的元素上
*/
if(list[j] == list[i])
next[i] = next[j];
else
next[i] = j;
System.out.println("next["+i+"]=" + next[i] );
} else
j = next[j];
}
return next;
}
public void kmp(char[] s , char[] m , int[] t) {
int len = s.length;
int number = m.length;
int j = 0;
int i = 0;
while(i < len && j < number) {
if(s[i] == m[j]) {
i++;
j++;
} else {
j = t[j];
if(j == -1) {
j = 0;
i++;
}
}
}
if(j == number) {
System.out.println("匹配位置:" + i);
}
}
/**
* @param args
*/
public static void main(String[] args) {
Kmp kmp = new Kmp();
char[] m = "abababb".toCharArray();
char[] s = "abababababb".toCharArray();
int[] next = kmp.getNext(m);
kmp.kmp(s,m,next);
}
}
/**
* 字符串匹配 kmp算法
* KMP算法实质:利用已经遍历得到的匹配信息来辅助后面的匹配过程
* @author bo
*
*/
public class Kmp {
/**
* next[j] = k 代表索引5的元素直接k-1个元素和开头k-1个元素相匹配(next数组表示 当pj元素失配的时候 需要把模式串向右移动到什么位置)
* 即p0...p(k-1) 和 p(j-k)...p(j-1) 相等
* 所以 0 < k < j
* @param list
* @return
*/
private int[] getNext(char[] list) {
int len = list.length;
int[] next = new int[len+1];
next[0] = -1;
int i = 0;
int j = -1; //代表k
System.out.println("netx[0]=-1");
while(i < (len - 1)) {
if(j == -1 || list[i] == list[j]) {
i++;
j++;
/*
* 当pk 和 pj 相等的时候 p(j+1) 如果不相等 需要移动到p(k+1)上
* 但是,如果p(j+1) = p(k+1) 即使移动也是陪同同一个字符 所以把p(j+1)不匹配问题转移到p(k+1)的元素上
*/
if(list[j] == list[i])
next[i] = next[j];
else
next[i] = j;
System.out.println("next["+i+"]=" + next[i] );
} else
j = next[j];
}
return next;
}
public void kmp(char[] s , char[] m , int[] t) {
int len = s.length;
int number = m.length;
int j = 0;
int i = 0;
while(i < len && j < number) {
if(s[i] == m[j]) {
i++;
j++;
} else {
j = t[j];
if(j == -1) {
j = 0;
i++;
}
}
}
if(j == number) {
System.out.println("匹配位置:" + i);
}
}
/**
* @param args
*/
public static void main(String[] args) {
Kmp kmp = new Kmp();
char[] m = "abababb".toCharArray();
char[] s = "abababababb".toCharArray();
int[] next = kmp.getNext(m);
kmp.kmp(s,m,next);
}
}
发表评论
-
NIO 简单实现的服务端和客户端通信
2015-06-29 11:35 690服务端代码如下: import java.io.IOExcep ... -
aaaaaaaaaaaa
2014-08-30 09:01 0111111111111111 -
struts2与checkbox的关系
2014-03-25 15:35 628Struts2 框架对checkbox的处理 1、 对于htm ... -
doc命令之关机管理
2014-03-21 09:26 689@echo off set /p p=是否关机(1:关机 2: ... -
金字塔最短路径
2014-03-18 10:02 581class Triangle { private int[] ... -
汉诺塔递归算法
2014-03-15 10:49 586class Hanio { private int st ... -
回溯算法之八皇后
2014-03-13 13:27 609public class EightQueens { ... -
xml的基本学习
2014-03-04 15:17 8851、 XML的概念 允许开发 ... -
软件生命三大测试的概念和区别
2014-02-17 22:01 0根据不同的测试阶段,测试可以分为单元测试、集成测试、系统测试和 ... -
Session处理同账号管理
2013-10-22 17:19 780首先使用HttpSessionAttributeListene ... -
线程概念
2013-03-20 21:06 0线程对可共享的、可改变的状态变量进行访问,需要实现协同,否则数 ... -
parseInt惹的祸
2013-03-04 17:57 819今天项目在实施的过程中,出现了让我懊恼的事情: 卡的金额读不出 ... -
Unable to retrieve metadata for procedure
2013-03-01 13:51 3921第一次用jdbc调用mysql存储过程的过程中犯了一个严重的错 ... -
JDK动态代理和CGLIB动态代理的学习
2012-10-08 17:25 0JDK动态代理是基于java.lang.reflect.Pro ... -
log4j输出spring框架的信息
2012-10-08 17:00 0log4j.logger.org.springframewor ... -
ReadWriteLock多线程下操作
2012-09-06 17:45 1009ReadWriteLock是实现多线程环境下同步的一种方式。与 ... -
WIN7 BCompare 启动应用程序发生错误
2012-08-24 11:26 1148WIN7下寻找: 把C:\用户\[用户名]\AppData\S ... -
ant
2012-08-24 11:15 0当使用-jar执行可执行Jar包时,JVM将Jar包所在目录设 ... -
java 学习
2012-08-14 21:18 632使用final声明的类不能有子类 使用final声明的方法不能 ... -
spring框架后处理器的学习
2012-07-27 09:22 744spring框架对容器管理bean和容器本身提供了额外增强功能 ...
相关推荐
算法 KMP算法 KMP算法 KMP算法 KMP算法 KMP算法 KMP算法 KMP算法 KMP算法 KMP算法 KMP算法 KMP算法 KMP
KMP算法,全称为Knuth-Morris-Pratt算法,是一种高效的字符串匹配算法,由Donald Knuth、Vaughan Morris和Robert Pratt三位学者提出。它的主要目标是在一个长字符串(主串A)中查找是否存在一个指定的短字符串(模式...
### 数据结果 KMP算法实验报告 #### 实验背景与目的 本实验主要针对《数据结构》课程中的字符串处理部分,具体涉及的是模式匹配算法——KMP算法。通过实验加深学生对串类型及其基本操作的理解,并重点掌握两种重要...
KMP算法,全称为Knuth-Morris-Pratt算法,是一种在字符串中寻找子串的高效搜索算法。它由D.E. Knuth、V. Morris和J.H. Pratt三位学者于1970年提出,主要用于解决模式匹配问题。传统的KMP算法避免了不必要的字符比较...
KMP算法是一种改进的字符串匹配算法,由Donald Knuth、Morris和Frank Pratt共同提出,其主要特点是在匹配过程中能够避免不必要的字符比较,从而提高搜索效率。 KMP算法的核心思想是构建一个部分匹配表(也称为失败...
`KMP算法.cpp`文件应该包含了这些实现逻辑,通过编译生成的`KMP算法.exe`可执行文件可以直接运行并测试。 4. **性能分析** KMP算法的时间复杂度为O(n + m),其中n为主串长度,m为子串长度。这是因为即使最坏情况下...
**KMP算法实现模板(C++版) ACM算法** KMP(Knuth-Morris-Pratt)算法是一种在文本字符串中查找子串匹配的有效方法,尤其适用于已经预处理了模式串(子串)的匹配信息。它是由D.E. Knuth、V. Morris和J.H. Pratt...
用C++语言实现的KMP算法。经过调试。供广大算法学习者参考。
"模式匹配的KMP算法" 模式匹配的KMP算法是计算机科学领域中的一种经典算法,用于解决串的模式匹配问题。该算法可以高效地查找目标串中是否包含某个模式串,并返回模式串在目标串中的起始位置。 模式匹配的KMP算法...
《字符串模式匹配KMP算法》教学课例设计 在这篇教学设计中,我们旨在帮助学生掌握KMP字符串模式匹配算法的基本概念和应用。通过本课例设计,学生将了解KMP算法的应用普遍性、实现机制和时间复杂度,并掌握计算next...
数据结构中的KMP算法是一种高效的字符串匹配算法,由D.E.Knuth、V.J.Morris和J.H.Pratt三位学者提出,因此得名KMP(Knuth-Morris-Pratt)。该算法主要用于在一个文本串中查找一个模式串(即目标字符串)是否存在。...
数据结构、kmp算法、代码实现、KMP(char *P,char *T,int *N,int start)
DS串应用--KMP算法DS串应用--KMP算法DS串应用--KMP算法DS串应用--KMP算法
BF 算法和 KMP 算法在字符串匹配中的应用 BF 算法和 KMP 算法是两种常用的字符串匹配算法,分别应用于不同的场景中。本文将对这两种算法进行详细的分析和比较,以便更好地理解它们的原理和应用。 BF 算法 BF ...
模式匹配中的KMP算法的实现 模式匹配是计算机科学领域中的一个研究热点,串的模式匹配算法是其中的一个重要分支。在模式匹配中,KMP算法是一个非常重要的算法,它可以高效地实现串的模式匹配。下面我们将详细介绍...
### 字符串KMP算法C语言实现解析 在计算机科学领域,字符串匹配是常见的操作之一,其中KMP算法(Knuth-Morris-Pratt算法)因其高效性而被广泛使用。KMP算法由Donald Knuth、James H.Morris以及Vaughan Pratt共同...
KMP算法,全称Knuth-Morris-Pratt算法,是一种高效的字符串匹配算法,由Donald Knuth、James H. Morris和 Vaughan Pratt三位学者在1970年提出。该算法主要用于解决在一个大文本串(A)中查找是否存在一个指定的小...
数据结构中KMP算法过程的Flash演示
在数据结构和算法的学习中,理解并掌握KMP算法对于解决字符串匹配问题至关重要。 KMP算法的核心是构建一个“部分匹配表”(也称为“失败指针”或“前缀函数”),它记录了子字符串的每一个前缀和后缀的最大公共长度...
kmp算法 KMP算法是一种改进的字符串匹配算法,由D.E.Knuth,J.H.Morris和V.R.Pratt同时发现,因此人们称它为克努特——莫里斯——普拉特操作(简称KMP算法)。KMP算法的关键是利用匹配失败后的信息,尽量减少模式串...