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数组去进行查找。
象书上都有详细的分析了,我再说一次,也不好。