BF算法 字符串匹配java代码实现

BF算法 字符串匹配java代码实现


     BF(Brute Force)算法核心思想是:首先S[1]和T[1]比较,若相等,则再比较S[2]和T[2],一直到T[M]为止;若S[1]和T[1]不等,则T向 右移动一个字符的位置,再依次进行比较。如果存在k,1≤k≤N,且S[k+1…k+M]=T[1…M],则匹配成功;否则失败。该算法最坏情况下要进行 M*(N-M+1)次比较, 时间复杂度为O(M*N)
     比如: String a ="123456789" String b= "23"
   其实就是循环 a一个一个字符匹配,开始a[0]和b[0]匹配,没有找到,直接不用找b[1],直接用a[1]和b[0]匹配发现已经 找到,然后继续用
a[2]和b[1]匹配发现已经 找到。前且是b字符串末尾。说明已经完全找到。返回结果
  JAVA代码实现
/**
     * 匹配字符串,判断 b字符串在a出现的起始位置,没有找到返回(-1)
     * @param a
     * @param b
     * @return
     */
    public static int indexOf(String a,String b){
        char[] as = a.toCharArray();
        char[] bs = b.toCharArray();
        int begin = 0;
        for(int i = 0 ; i <as.length; i++){
            int k = nextStr(as[i], bs,begin);
            //说明已经找到
            if( k == begin ){
                return i-begin;
            }
            //说明找到一个字符,需要继续找
            else if( k >= 0 ){
                begin = k;
            }else{
            //没有找到继续找    
            begin = 0;
            }
        }
        return -1;
    }
    
    
    /**
     * 匹配字符串,找到字符串位置
     * @param c
     * @param cs
     * @param begin
     * @return
     */
    public static int nextStr(char c,char[] cs,int begin){
        //如果字符匹配和已经到了字符尾部青示已经全部匹配
        if(cs[begin] == c && begin == (cs.length-1) ){
            return begin;
        //如果字符匹配但没有到尾部需要继续下移
        }else if(cs[begin] == c){
            return begin+1;
        }
        //完全没有匹配
        else{
            return -1;
        }
    }

 然后在main里面调用indexOf方法看到结果

你可能感兴趣的:(BF算法 字符串匹配java代码实现)