Sha256: 6429c06d7f445e3ac788fb7c5c681276e3392644128287849cda5a741215accc
Contents?: true
Size: 723 Bytes
Versions: 73
Compression:
Stored size: 723 Bytes
Contents
module RailsGuides module Levenshtein # Based on the pseudocode in http://en.wikipedia.org/wiki/Levenshtein_distance def self.distance(s1, s2) s = s1.unpack('U*') t = s2.unpack('U*') m = s.length n = t.length # matrix initialization d = [] 0.upto(m) { |i| d << [i] } 0.upto(n) { |j| d[0][j] = j } # distance computation 1.upto(m) do |i| 1.upto(n) do |j| cost = s[i] == t[j] ? 0 : 1 d[i][j] = [ d[i-1][j] + 1, # deletion d[i][j-1] + 1, # insertion d[i-1][j-1] + cost, # substitution ].min end end # all done return d[m][n] end end end
Version data entries
73 entries across 73 versions & 3 rubygems