gem algorithms0.1.0 算法部分Algorithms::Search分析1

gem algorithms0.1.0 算法部分Algorithms::Search分析1
我这不算是分析源码了,只算是自己读一遍,顺便记下所得。
不过,就像有人说,写文章不是为了取悦于他人,写文章是为了把自己给说服,因为一定要诚实的写,不要作假。为此,继续。
def self.binary_search(container, item)
    return nil if item.nil?
    low = 0
    high = container.size - 1
    while low <= high
      mid = (low + high) / 2
      val = container[mid]
      if val > item
        high = mid - 1
      elsif val < item
        low = mid + 1
      else
        return val
      end
    end
    nil
  end
  这个程序实现了二分查找算法。当数组已经排好顺序时,可用。

  下面程序实现了kmp字串查找方法。
   def self.kmp_search(string, substring)
    return nil if string.nil? or substring.nil?
    
    # create failure function table
    pos = 2
    cnd = 0
    failure_table = [-1, 0]
    while pos < substring.length
      if substring[pos - 1] == substring[cnd]
        failure_table[pos] = cnd + 1
        pos += 1
        cnd += 1
      elsif cnd > 0
        cnd = failure_table[cnd]
      else
        failure_table[pos] = 0
        pos += 1
      end
    end

    m = i = 0
    while m + i < string.length
      if substring[i] == string[m + i]
        i += 1
        return m if i == substring.length
      else
        m = m + i - failure_table[i]
        i = failure_table[i] if i > 0
      end
    end
    return nil
  end
 依希有点数据结构书上的影子,先根据目标串建立next数组,再根据next数组去进行查找。
 象书上都有详细的分析了,我再说一次,也不好。
 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值