KMP

KMP算法

KMP原理

KMPnext



    public static void main(String[] args) {
        String a="VERDI";
        char[] pattern=a.toCharArray();
        int[] prefix=next(pattern);
        String b="AXIVVERDIYERDIAN";
        char[] original=b.toCharArray();
        System.out.println(SearchPattern(original, pattern));

    }
    public static int SearchPattern(char[] original,char[] pattern){
        int[] next=next(pattern);
         int j = 0;  
            for (int i = 0; i < original.length; i++) {  
                while (j > 0 && original[i]!= pattern[j])   
                    j = next[j-1];  
                if (original[i] == pattern[j])  
                    j++;  
                if (j == pattern.length) {  
                    //System.out.println("find at position " + (i - j));  
                    //System.out.println(original.subSequence(i-j+ 1, i + 1));  
                    //j = next[j];
                    return i-j+1;
                }  
            }  
        return 0;
    }
    public static int[] next(char[] pattern){
        int length=pattern.length;
        int[] prefix=new int[length];
        prefix[0]=0;

         for(int i=1; i<length; i++)

         {

             int k=prefix[i-1];

             //不断递归判断是否存在子对称,k=0说明不再有子对称,Pattern[i] != Pattern[k]说明虽然对称,但是对称后面的值和当前的字符值不相等,所以继续递推

             while( pattern[i] != pattern[k]  &&  k!=0 )               

                 k=prefix[k-1];     //继续递归

             if( pattern[i] == pattern[k])//找到了这个子对称,或者是直接继承了前面的对称性,这两种都在前面的基础上++

                  prefix[i]=k+1;

             else

                  prefix[i]=0;       //如果遍历了所有子对称都无效,说明这个新字符不具有对称性,清0

         }
         return prefix;
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值