Files
2022-01-20 20:30:18 +01:00

3.1 KiB

id, title, challengeType, forumTopicId, dashedName
id title challengeType forumTopicId dashedName
5e4ce2eaac708cc68c1df260 レーベンシュタイン距離 5 385264 levenshtein-distance

--description--

情報理論とコンピュータサイエンスでは、レーベンシュタイン距離 は 2 つのシーケンスがどの程度異なっているかを測定するための [メトリック](https://en.wikipedia.org/wiki/string metric) です ([編集距離](https://en.wikipedia.org/wiki/edit distance)ともいう)。 2 つの文字列間のレーベンシュタイン距離は、1 つの文字の挿入、削除、置換を行うことで、1 つの文字列をもう 1 つの文字列に変換するために必要な最小編集回数として定義されます。

例:

"kitten" と "sitting" の間のレーベンシュタイン距離は 3 です。以下の 3 回で一方から他方へと変換され、かつ 3 回より少ない回数の編集でこの変換を行う方法がないからです。

  • kitten   sitten    ('k' を 's' で置換)
  • sitten   sittin    ('e' を 'i' で置換)
  • sittin   sitting    (最後に 'g' を挿入)

"rosettacode" と "raisethysword" とのレーベンシュタイン距離は 8 となります。

2つの文字列間のレーベンシュタイン距離は、両方の文字列を逆にした場合も同じです。

--instructions--

パラメータとして与えられた 2 つの文字列間のレーベンシュタイン距離を返す関数を記述してください。

--hints--

levenshtein は関数とします。

assert(typeof levenshtein == 'function');

levenshtein("mist", "dist") は数値を返す必要があります。

assert(typeof levenshtein('mist', 'dist') == 'number');

levenshtein("mist", "dist")1 を返す必要があります。

assert.equal(levenshtein('mist', 'dist'), 1);

levenshtein("tier", "tor")2 を返す必要があります。

assert.equal(levenshtein('tier', 'tor'), 2);

levenshtein("kitten", "sitting")3 を返す必要があります。

assert.equal(levenshtein('kitten', 'sitting'), 3);

levenshtein("stop", "tops")2 を返す必要があります。

assert.equal(levenshtein('stop', 'tops'), 2);

levenshtein("rosettacode", "raisethysword")8 を返す必要があります。

assert.equal(levenshtein('rosettacode', 'raisethysword'), 8);

levenshtein("mississippi", "swiss miss")8 を返す必要があります。

assert.equal(levenshtein('mississippi', 'swiss miss'), 8);

--seed--

--seed-contents--

function levenshtein(a, b) {

}

--solutions--

function levenshtein(a, b) {
  var t = [], u, i, j, m = a.length, n = b.length;
  if (!m) { return n; }
  if (!n) { return m; }
  for (j = 0; j <= n; j++) { t[j] = j; }
  for (i = 1; i <= m; i++) {
    for (u = [i], j = 1; j <= n; j++) {
      u[j] = a[i - 1] === b[j - 1] ? t[j - 1] : Math.min(t[j - 1], t[j], u[j - 1]) + 1;
    } t = u;
  } return u[n];
}