Sha256: 768a0b953ae6dcab9955faee9cca1a07c4b2a7bb09d0a792be2ce78e6f14035c
Contents?: true
Size: 722 Bytes
Versions: 9
Compression:
Stored size: 722 Bytes
Contents
module JaxGuides 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
9 entries across 9 versions & 1 rubygems