java实现的KMP算法

public class KMPAlgorithm { 

 

    /**

     * 计算模式串的next函数

     * 

     * @param desStr

     *            模式串

     * @return 模式串的next函数,用数组来保存

     */ 

    private static int[] kmpNext(String desStr) { 

        int len = desStr.length(); 

        int i = 0; 

        int j = -1; 

        int next[] = new int[len]; 

        while (i < len - 1) { 

            if (j == -1 || (desStr.charAt(i) == (desStr.charAt(j)))) { 

                i++; 

                j++; 

                if (desStr.charAt(i) != (desStr.charAt(j))) { 

                    next[i] = (j + 1); 

                } else { 

                    next[i] = next[j]; 

                } 

            } else { 

                j = (next[j] - 1); 

            } 

        } 

        return next; 

 

    } 

 

    /**

     * kmp的核心算法

     * 

     * @param sourceStr

     * @param desStr

     * @param pos

     *            从主串的第几个字符开始匹配

     * @return 成功的话返回位置,失败的话返回-1,索引从0开始的

     */ 

    public static int index(String sourceStr, String desStr, int pos) { 

        int next[] = kmpNext(desStr); 

        int i = 0; 

        int j = 0; 

        while (i < sourceStr.length() - 1 && j < desStr.length() - 1) { 

            if (j == 0 || (sourceStr.charAt(i) == desStr.charAt(j))) { 

                i++; 

                j++; 

            } else 

                j = (next[j] - 1); 

        } 

        if (j > desStr.length() - 2) { 

            return (i - desStr.length() + 1); 

        } else 

            return -1; 

 

    } 

 

}  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值