zoukankan      html  css  js  c++  java
  • KMP算法的JAVA实现

    package kmp;
    
    import java.util.ArrayList;
    import java.util.HashMap;
    import java.util.Map;
    
    public class KMP {
        
        /*
         * 计算key的部分匹配表
         */
        private static Map<String,Integer>getPartialMatchTable(String str)
        {
            Map<String,Integer> result = new HashMap<String,Integer>();
            
            int length = str.length();
            
            for(int i = 1; i<=length; i++)
            {
                String partial = str.substring(0, i);
                
                int value = KMP.getPartialValue(partial);
                
                result.put(partial, value);    
            }
            return result;
        }
        
        /*
         * 计算string的部分匹配值
         */
        private static int getPartialValue(String str)
        {
            int result =0;
            
            int length = str.length();
            
            for(int i =1; i<length; i++)
            {
                if( str.substring(0,i).equals(str.substring(length-i, length)))
                    result = i;
            }
            
            return result;
        }
        
        public static ArrayList<Integer> kmp(String searchString,String key)
        {
            ArrayList<Integer> result = new ArrayList<Integer>();
            
            Map<String,Integer> partialMatchTable = KMP.getPartialMatchTable(key);
            
            int length = searchString.length();
            
            int step =1;
            
            for(int i = 0; i < length; i = i+step)            
            {
                for(int j = 0; j < key.length(); j ++)
                {
                    if(searchString.charAt(i+j) == key.charAt(j))
                    {
                        if(j == key.length()-1)
                        {
                            //如果匹配正确记录下来并step 赋值为1
                            result.add(i);
                            
                            step = 1;
                        }
                    }else{
                        //step = 已匹配的值-部分匹配值
                        step = j - partialMatchTable.get(key.substring(0, j+1));
                        
                        if(step == 0)
                        {
                            step =1;
                        }
                        break;
                    }
                }
            }
            
            
            return result;
        }
    
        /**
         * @param args
         */
        public static void main(String[] args) {
            // TODO Auto-generated method stub
            
            String temp = "ABCABC";
            
            String search = "ABABCABCHSIIAABCABCHSJDKAABCABCH";
            
            ArrayList<Integer> result = KMP.kmp(search, temp);
            
            for(Integer i:result )
            {
                System.out.println(i);
            }
    
        }
    
    }
    坚定目标,向前看
  • 相关阅读:
    vue 鼠标移入移出事件执行多次(尤其ie)
    jquery input file 多图上传,单张删除,查看
    pc端vue 滚动到底部翻页
    element-ui默认样式修改
    element-ui上传一张图片后隐藏上传按钮
    echarts字体适配
    SQLServer之查询当前服务器下所有目录视图表
    SQLServer之服务器连接
    React学习之路之创建项目
    SQLServer之列数据转换为行数据
  • 原文地址:https://www.cnblogs.com/wangcansun/p/3494264.html
Copyright © 2011-2022 走看看