算法之KMP算法代码示例

package com.sun.test.student;

public class KMP算法 {

    public static int[] getNext(String ps) {
        char[] p = ps.toCharArray();
        int[] next = new int[p.length];
        next[0] = -1;
        //next[]数组的下标与原数组的下标
        int j = 0;
        //移动到上一个匹配点的下标为next[]的值
        int k = -1;
        while (j < p.length - 1) {
           if (k == -1 || p[j] == p[k]) {
              /*   因为  p[0~k-1]==p[j-k~j-1](next[j]=k) 
               *   所以 next[j+1]==next[j]+1=k+1;
               * */
               //代码思路,如果相等 j,k下标后移。  如果k=-1,初始化
               j++;
               k++;
               next[j] = k;
           } else {
                      /* 反推法:next[k]=next[j]
                       * 因为 next[j]=k;所以 k=next[k];
                       * */
               //代码思路,如果不相等,获得p[k]指向的区域下标即next[k]。赋值给k,为下面开始比较做准备
               k = next[k];
           }
        }
        return next;
    }
    public static int KMP(String ts, String ps) {
        char[] t = ts.toCharArray();
        char[] p = ps.toCharArray();
        int i = 0; // 主串的位置
        int j = 0; // 模式串的位置
        int[] next = getNext(ps);
        while (i < t.length && j < p.length) {
           if (j == -1 || t[i] == p[j]) { // 当j为-1时,要移动的是i,当然j也要归0
               i++;
               j++;

           } else {
               // i不需要回溯了
               // i = i - j + 1;
               j = next[j]; // j回到指定位置
           }
        }
        if (j == p.length) {
           return i - j;
        } else {
           return -1;
        }
    }
    public static void main(String[] args) {
        int[] next=getNext("ssssassss");
         for(int n:next){
                System.out.println(n);
            }
    }
}

 

posted @ 2020-08-10 15:04  sunjinwei123  阅读(363)  评论(0)    收藏  举报