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
原创粉丝点击