4
对于Levenshtein算法,我找到了this implementation for Delphi。Levenshtein算法 - 如果编辑距离大于给定阈值,则快速失败
我需要一个版本,一旦遇到最大距离就停下来,并返回到目前为止发现的距离。
我的第一个想法是后检查当前结果每次迭代:
for i := 1 to n do
for j := 1 to m do
begin
d[i, j] := Min(Min(d[i-1, j]+1, d[i,j-1]+1), d[i-1,j-1]+Integer(s[i] <> t[j]));
// check
Result := d[n, m];
if Result > max then
begin
Exit;
end;
end;
这是没有好。你分配给'd [i,j]',然后测试'd [n,m]'。另外,'ord()'会比'Integer()'更普通,但我更喜欢显式使用'IfThen()'。如果n或m小于1,结果将不会被分配。 – 2012-07-31 08:16:40
我看到,Min的使用使得在两个循环结束前难以优化。 – mjn 2012-07-31 09:45:24