Not logged in.  Login/Logout/Register | List snippets | | Create snippet | Upload image | Upload data

38
LINES

< > BotCompany Repo | #1000388 // leven - Levenshtein string distance function in JavaX

JavaX fragment (include) [tags: use-pretranspiled]

Libraryless. Click here for Pure Java version (63L/1K).

static int leven(S s, S t) {
  // degenerate cases
  if (s.equals(t)) return 0;
  int ls = s.length(), lt = t.length();
  if (ls == 0) return lt;
  if (lt == 0) return ls;

  // create two work vectors of integer distances
  int[] v0 = new int[lt + 1];
  int[] v1 = new int[lt + 1];

  // initialize v0 (the previous row of distances)
  // this row is A[0][i]: edit distance for an empty s
  // the distance is just the number of characters to delete from t
  for (int i = 0; i < v0.length; i++)
      v0[i] = i;

  for (int i = 0; i < ls; i++)
  {
      // calculate v1 (current row distances) from the previous row v0

      // first element of v1 is A[i+1][0]
      //   edit distance is delete (i+1) chars from s to match empty t
      v1[0] = i + 1;

      // use formula to fill in the rest of the row
      for (int j = 0; j < lt; j++)
      {
          int cost = s.charAt(i) == t.charAt(j) ? 0 : 1;
          v1[j + 1] = Math.min(Math.min(v1[j] + 1, v0[j + 1] + 1), v0[j] + cost);
      }

      // swap arrays
      int[] v = v1; v1 = v0; v0 = v;
  }

  return v0[lt];
}

Author comment

from Wikipedia, translated to JavaX

download  show line numbers  debug dex  old transpilations   

Travelled to 17 computer(s): aoiabmzegqzx, bhatertpkbcr, cbybwowwnfue, cfunsshuasjs, ddnzoavkxhuk, ekrmjmnbrukm, gwrvuhgaqvyk, ishqpsrjomds, lpdgvwnxivlt, mqqgnosmbjvj, onxytkatvevr, pyentgdyhuwx, pzhvpgtvlbxg, tslmcundralx, tvejysmllsmz, vouqrxazstgt, whxojlpjdney

No comments. add comment

Snippet ID: #1000388
Snippet name: leven - Levenshtein string distance function in JavaX
Eternal ID of this version: #1000388/4
Text MD5: d5a257ec5dec20df71bacac86510ca3e
Transpilation MD5: d43f5c3c26a20be2332b7f990eb40401
Author: stefan
Category: javax
Type: JavaX fragment (include)
Public (visible to everyone): Yes
Archived (hidden from active list): No
Created/modified: 2019-11-20 00:19:02
Source code size: 1117 bytes / 38 lines
Pitched / IR pitched: No / No
Views / Downloads: 736 / 2949
Version history: 3 change(s)
Referenced in: #695 - IOIOI Processor (v10)
#704 - IOIOI Processor (v11)
#705 - An experiment with predictors
#716 - IOIOI Processor (v12, "descent of choices")
#717 - IOIOI Processor (v13)
#720 - IOIOI Processor (v14, changing examples to Object)
#722 - IOIOI Processor (v15)
#1000389 - Levenshtein distance function test
#1000398 - Levenshtein distance function test
#1000559 - Text diff function in JavaX (char-based, based on levenshtein distance, developing [maybe])
#1006654 - Standard functions list 2 (LIVE, continuation of #761)
#1022301 - levenIC - case-insensitive Levenshtein string distance function in JavaX
#3000382 - Answer for ferdie (>> t = 1, f = 0)
#3000383 - Answer for funkoverflow (>> t=1, f=0 okay)