KMP

/*
 * To change this template, choose Tools | Templates
 * and open the template in the editor.
 */
package array;

/**
 *
 * @author liuyuan
 */
public class KMP_practice {

    int m, n, f[];
    String str, pat;

    public KMP_practice(String str, String pat) {
        this.str = str;
        this.pat = pat;
        m = pat.length();
        n = str.length();
        f = new int[m];
    }

    public void Fail() {
        f[0] = -1;
        int i;
        for (int j = 1; j < m; j++) {
            i = f[j - 1];
            while (pat.charAt(j) != pat.charAt(i + 1) && i != -1) {
                i = f[i];
            }
            if (pat.charAt(j) == pat.charAt(i + 1)) {
                f[j] = i + 1;
            } else {
                f[j] = -1;
            }
        }
    }

    public int FastFind() {
        Fail();
        int p = 0, s = 0;
        while (p < m && s < n) {
            if (pat.charAt(p) == str.charAt(s)) {
                p++;
                s++;
            } else if (p == 0) {
                s++;
            } else {
                p = f[p - 1] + 1;
            }
        }
        if (p == m) {
            return s - m;
        } else {
            return -1;
        }
    }

    public static void main(String[] args) {
        KMP_practice test = new KMP_practice("aaaaaba", "ab");
        System.out.println(test.FastFind());
    }
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值