-
Notifications
You must be signed in to change notification settings - Fork 22
Expand file tree
/
Copy pathminEditDistance.js
More file actions
38 lines (34 loc) · 825 Bytes
/
minEditDistance.js
File metadata and controls
38 lines (34 loc) · 825 Bytes
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
/**
* matrix[i][j] = Math.min(
* matrix[i - 1][j] + 1,
* matrix[i][j - 1] + 1,
* matrix[i - 1][j - 1] + (str1[i - 1] === str2[j - 1] ? 0 : 1)
* );
*/
export default function minEditDistance(str1, str2) {
if (!str1 || !str2) {
return Math.max(str1.length, str2.length);
}
const len1 = str1.length;
const len2 = str2.length;
const matrix = [];
for (let i = 0; i <= len1; i++) {
matrix[i] = [];
for (let j = 0; j <= len2; j++) {
if (i === 0) {
matrix[i][j] = j;
}
else if (j === 0) {
matrix[i][j] = i;
}
else {
matrix[i][j] = Math.min(
matrix[i - 1][j] + 1,
matrix[i][j - 1] + 1,
matrix[i - 1][j - 1] + (str1[i - 1] === str2[j - 1] ? 0 : 1)
);
}
}
}
return matrix[len1][len2];
}