`
zjxs_sky100
  • 浏览: 28413 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

KMP算法

阅读更多
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算法KMP算法KMP算法

    KMP算法

    KMP算法算法 KMP算法 KMP

    算法 KMP算法 KMP算法 KMP算法 KMP算法 KMP算法 KMP算法 KMP算法 KMP算法 KMP算法 KMP算法 KMP算法 KMP

    KMP算法详解 KMP算法详解

    KMP算法详解KMP算法详解KMP算法详解KMP算法详解KMP算法详解

    kMP算法JavakMP算法JavakMP算法JavakMP算法Java

    kMP算法JavakMP算法JavakMP算法JavakMP算法JavakMP算法JavakMP算法JavakMP算法JavakMP算法JavakMP算法JavakMP算法JavakMP算法JavakMP算法JavakMP算法JavakMP算法JavakMP算法JavakMP算法JavakMP算法JavakMP算法Java...

    KMP算法详解KMP算法详解

    KMP算法详解KMP算法详解KMP算法详解KMP算法详解

    C++实现的KMP算法

    用C++语言实现的KMP算法。经过调试。供广大算法学习者参考。

    kmp算法的代码实现

    数据结构、kmp算法、代码实现、KMP(char *P,char *T,int *N,int start)

    数据结果 kmp算法实验报告

    kmp算法,数据结构的实验报告,大学实验报告,希望能帮到大家

    KMP算法Flash演示

    数据结构中KMP算法过程的Flash演示

    Python实现字符串匹配的KMP算法

    kmp算法 KMP算法是一种改进的字符串匹配算法,由D.E.Knuth,J.H.Morris和V.R.Pratt同时发现,因此人们称它为克努特——莫里斯——普拉特操作(简称KMP算法)。KMP算法的关键是利用匹配失败后的信息,尽量减少模式串...

    DS串应用--KMP算法

    DS串应用--KMP算法DS串应用--KMP算法DS串应用--KMP算法DS串应用--KMP算法

    Kmp算法Java实现源码

    KMP算法是通过分析子串,预先计算每个位置发生不匹配的时候,所需GOTO的下一个比较位置,整理出来一个next数组,然后在上面的算法中使用。

    数据结构课程设计-kmp算法

    KMP算法是对一般模式匹配算法的改进,由D.E.Knuth与V.R.Pratt和J.H.Morris 同时发现的因此人们称它为克努特-莫里斯-莫拉特操作(简称为KMP算法)。 对于一般的模式匹配算法:分别利用两个指针i和j指示主串S和T中的...

    KMP算法 严蔚敏版

    此程序配合清华大学出版《数据结构(C语言版)》 P83-84页的KMP算法 win tc调试通过

    kmp算法实现

    KMP算法实现 KMP算法实现 KMP算法实现 KMP算法实现

    KMP算法(C++)示例代码

    KMP算法是一种改进的字符串匹配算法,由D.E.Knuth,J.H.Morris和V.R.Pratt提出的,因此人们称它为克努特—莫里斯—普拉特操作(简称KMP算法)。KMP算法的核心是利用匹配失败后的信息,尽量减少模式串与主串的匹配...

    kmp算法.ppt

    kmp算法的原理以及kmp算法的源代码

    模式匹配:KMP算法

    使用KMP算法实现模式匹配,包括next数组的求解,kmp算法的实现。关键代码有详细注释。

    KMP算法的实现

    KMP算法的实现, 这程序代码是基于KMP算法来实现的,虽然很简单,但是可能也会对你有帮助的

    利用KMP算法进行子串的快速查找

    利用KMP算法进行子串的快速查找,能够达到较高的速率

Global site tag (gtag.js) - Google Analytics