String KMP算法 JAVA实现

字符串的匹配算法最经典的算法还是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
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值