mirror of
https://github.com/GravitLauncher/Launcher
synced 2025-01-25 08:39:21 +03:00
35 lines
1.5 KiB
Java
35 lines
1.5 KiB
Java
|
package pro.gravit.launchserver.helper;
|
||
|
|
||
|
public class DamerauHelper {
|
||
|
//Расстояние Дамерау — Левенштейна. GitHub https://github.com/crwohlfeil/damerau-levenshtein
|
||
|
public static int calculateDistance(CharSequence source, CharSequence target) {
|
||
|
if (source == null || target == null) {
|
||
|
throw new IllegalArgumentException("Parameter must not be null");
|
||
|
}
|
||
|
int sourceLength = source.length();
|
||
|
int targetLength = target.length();
|
||
|
if (sourceLength == 0) return targetLength;
|
||
|
if (targetLength == 0) return sourceLength;
|
||
|
int[][] dist = new int[sourceLength + 1][targetLength + 1];
|
||
|
for (int i = 0; i < sourceLength + 1; i++) {
|
||
|
dist[i][0] = i;
|
||
|
}
|
||
|
for (int j = 0; j < targetLength + 1; j++) {
|
||
|
dist[0][j] = j;
|
||
|
}
|
||
|
for (int i = 1; i < sourceLength + 1; i++) {
|
||
|
for (int j = 1; j < targetLength + 1; j++) {
|
||
|
int cost = source.charAt(i - 1) == target.charAt(j - 1) ? 0 : 1;
|
||
|
dist[i][j] = Math.min(Math.min(dist[i - 1][j] + 1, dist[i][j - 1] + 1), dist[i - 1][j - 1] + cost);
|
||
|
if (i > 1 &&
|
||
|
j > 1 &&
|
||
|
source.charAt(i - 1) == target.charAt(j - 2) &&
|
||
|
source.charAt(i - 2) == target.charAt(j - 1)) {
|
||
|
dist[i][j] = Math.min(dist[i][j], dist[i - 2][j - 2] + cost);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
return dist[sourceLength][targetLength];
|
||
|
}
|
||
|
}
|