多应用+插件架构,代码干净,二开方便,首家独创一键云编译技术,文档视频完善,免费商用码云13.8K 广告
## 问题 你想对两个或多个字符串进行匹配。 ## 方法 计算编辑距离,即计算把某个字符串转为另外一个字符串需要操作的次数。 ~~~ Levenshtein = (str1, str2) -> l1 = str1.length l2 = str2.length Math.max l1, l2 if Math.min l1, l2 == 0 i = 0; j = 0; distance = [] for i in [0...l1 + 1] distance[i] = [] distance[i][0] = i distance[0][j] = j for j in [0...l2 + 1] for i in [1...l1 + 1] for j in [1...l2 + 1] distance[i][j] = Math.min distance[i - 1][j] + 1, distance[i][j - 1] + 1, distance[i - 1][j - 1] + if (str1.charAt i - 1) == (str2.charAt j - 1) then 0 else 1 distance[l1][l2] ~~~ ## 详解 你可以使用Hirschberg或者Wagner-Fischer的算法来计算编辑距离。上例使用的是Wagner-Fischer算法。