私はここに座って、メイン プログラムのいくつかのアルゴリズムを Java でプログラミングしています (これまでのところ最初のアルゴリズムです)。初心者向けの疑似コードと素敵なチュートリアルを備えた wiki のおかげで、レーベンシュタイン アルゴリズムをうまくプログラムできました :D
次に、Damerau にアップグレードして余分な行を追加することにしましたが、それは DL アルゴではなく OptimalStringAlignmentDistance であると読みました。actionscript コードを読んで、DL にするにはさらに何を追加する必要があるかを理解しようとしましたが、混乱してしまいました。私はJavaに似たコードでさまざまな場所に行ったことがありますが、それらはすべて間違った擬似コードも使用しています。
半日過ごして諦めてこちらにお願いすることにしました。このコードを Java の Damerau-Levenshtein にアップグレードするのを手伝ってくれる人はいますか?
public class LevensteinDistance {
private static int Minimum(int a, int b, int c) {
return Math.min(Math.min(a, b), c);
}
private static int Minimum (int a, int b) {
return Math.min(a, b);
}
public static int computeLevensteinDistance(String s, String t){
int d[][];
int n; // length of s
int m; // length of t
int i; // iterates through s
int j; // iterates through t
char s_i; // ith character of s
char t_j; // jth character of t
int cost; // cost
n = s.length ();
m = t.length ();
if (n == 0) {
return m;
}
if (m == 0) {
return n;
}
d = new int[n+1][m+1];
for (i = 0; i <= n; i++) {
d[i][0] = i;
}
for (j = 0; j <= m; j++) {
d[0][j] = j;
}
for(i = 1; i <= n; i++) {
s_i = s.charAt (i - 1);
for(j = 1; j <= m; j++) {
t_j = t.charAt (j - 1);
if(s_i == t_j){
cost = 0;
}else{
cost = 1;
}
d[i][j] = Minimum(d[i-1][j]+1, d[i][j-1]+1, d[i-1][j-1] + cost);
if(i > 1 && j > 1 && s_i == t_j-1 && s_i-1 == t_j){
d[i][j] = Minimum(d[i][j], d[i-2][j-2] + cost);
}
}
}
return d[n][m];
}
// public static void main(String[] args0){
// String a = "I decided it was best to ask the forum if I was doing it right";
// String b = "I thought I should ask the forum if I was doing it right";
// System.out.println(computeLevensteinDistance(a, b));
// }
}
ダメラウ・レーベンシュタイン距離アルゴリズムのウィキペディアのページは次のとおりです。