How can I compute a difference between two strings?

前端 未结 2 752
难免孤独
难免孤独 2020-12-30 08:32

I want to create a function in Delphi that computes different levels of two strings. If two strings are equal (ignoring case), then it should return 0, but if they are not e

2条回答
  •  情歌与酒
    2020-12-30 08:51

    Fast and compact implementation.

    About 3 times as fast as smasher's implementation with normal strings. More than 100 times as fast if one of the strings is empty.

    Smasher's function is case insensitive though, which can be useful as well.

    function LevenshteinDistance(const s, t: string): integer;inline;
    var
      d   : array of array of integer;
      n, m, i, j : integer;
    begin
      n := length(s);
      m := length(t);
      if n = 0 then Exit(m);
      if m = 0 then Exit(n);
    
      SetLength(d, n + 1, m + 1);
      for i := 0 to n do d[i, 0] := i;
      for j := 0 to m do d[0, j] := j;
    
      for i := 1 to n do
        for j := 1 to m do
          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]));
    
      Result := d[n, m];
    end;
    

    Note: the inline directive reduces the execution time to less than 70% on my machine, but only for the win32 target platform. If you compile to 64bits (Delphi XE2), inlining actually makes it a tiny bit slower.

提交回复
热议问题