String KMP算法 JAVA实现
来源:互联网 发布:adobe xd windows 编辑:程序博客网 时间:2024/06/07 02:52
字符串的匹配算法最经典的算法还是KMP算法,网上有很多的KMP算法的解释流程这里不需详细解释,KMP算法最重要的是计算模式字符串pat的next数组,小弟在这里用Java写了next数组的实现,需要知道详细next数组求法的可以到网上找,这里直接给出代码:
//next数组,用来确定一个模式字符串的next数组KMP算法的关键。 public static int[] next(String pat){ int N=pat.length(); int[] a=new int[N]; a[0]=0; a[1]=1; for(int i=2;i<N;i++){ a[i]=next(pat,i-1,i-1,a); } return a; } //递归找出next 数组的值,j是确定的值,i是变化的值,递归的关键 public static int next(String pat,int j,int i,int[] a){ while(j>0) if(pat.charAt(i)==pat.charAt(a[j]-1)){ return a[j]+1; } else return next(pat, a[j]-1,i, a); return 1; }
这里的next数组是0,1开始的,也可以写成-1,0开始的,就是整体加1,求出next数组之后,对KMP的算法实现就如下:
public static int KMP(String pat,String text){//pat是模式字符串 int N=pat.length(); int M=text.length(); int[] next=next(pat); int k=0; int j=0; while(k<M){ if(pat.charAt(j)==text.charAt(k)) { j++; k++; } else { if(j==0) k++; else j=next[j]-1; } System.out.print((k-1)+" "); if(j==N) return j; //匹配成功 } return -1;//匹配失败 }
需要知道具体流程的可以到网上找,哈哈,最后测试算法的正确性:
//test public static void main(String[] args) { String s="abcabcabdabba"; String c="abcabd"; int t=KMP(c,s); if(t==c.length()){ System.out.println("匹配成功"); } else System.out.println("匹配失败~!!!"); }
测试结果如下
0 1 2 3 4 4 5 6 7 8 匹配成功.
1 0
- String KMP算法 JAVA实现
- java实现kmp算法
- KMP算法java实现
- Java实现KMP算法
- KMP算法java实现
- KMP算法----java实现
- KMP算法java实现
- KMP算法Java实现
- KMP 算法 java实现
- Java实现KMP算法
- KMP算法Java实现
- KMP算法java实现
- KMP算法-Java实现
- KMP算法java实现
- KMP算法JAVA实现
- Java实现KMP算法
- KMP算法 Java实现
- KMP算法java实现
- 43. Multiply Strings
- Ajax 与异步数据传输
- Eclipse查看Jar包中的源码配置和下载(超简单)
- Shell中,实现单一实例(译)
- 独立模式(Standone Mode)启动Spark
- String KMP算法 JAVA实现
- JQuery初识
- Java/Jsp中让数值不使用科学计数法显示的解决方案
- 【私人手册】Markdown语法
- mybatis 基本类型的if条件判断问题 There is no getter for property named 'xxx' in 'class Java.lang.Integer'
- [ML]机器学习之线性回归
- snort 源码分析之模式匹配引擎
- 文章标题
- banner(图片轮播)框架的使用