Rumah >Java >javaTutorial >Bagaimanakah algoritma Levenshtein boleh digunakan untuk mengira jarak edit dan menentukan persamaan antara dua rentetan di Jawa?

Bagaimanakah algoritma Levenshtein boleh digunakan untuk mengira jarak edit dan menentukan persamaan antara dua rentetan di Jawa?

DDD
DDDasal
2024-11-18 06:28:02505semak imbas

How can the Levenshtein algorithm be used to calculate edit distance and determine the similarity between two strings in Java?

Perbandingan Rentetan Kesamaan dalam Java

Apabila membandingkan berbilang rentetan untuk mengenal pasti rentetan yang paling serupa, adalah penting untuk memanfaatkan teknik dan algoritma yang sesuai. Artikel ini menyelidiki pendekatan yang digunakan secara meluas dikenali sebagai "jarak edit" untuk mengira persamaan antara dua rentetan.

Mengira Jarak Edit menggunakan Algoritma Levenshtein

Mengira suntingan jarak melibatkan penentuan bilangan minimum sisipan aksara, pemadaman dan penggantian yang diperlukan untuk mengubah satu rentetan kepada rentetan yang lain. Algoritma Levenshtein ialah pendekatan klasik untuk mengira jarak suntingan, selalunya dimasukkan ke dalam perpustakaan pengaturcaraan. Untuk mengira menggunakan algoritma Levenshtein:

// Levenshtein's Edit Distance Function
public static int editDistance(String s1, String s2) {
    // Convert to lower case for case-insensitive comparison
    s1 = s1.toLowerCase();
    s2 = s2.toLowerCase();

    int[][] matrix = new int[s2.length() + 1][s1.length() + 1];

    // Initialize first column to cost of insertion
    for (int i = 0; i <= s1.length(); i++) {
        matrix[0][i] = i;
    }

    // Initialize first row to cost of deletion
    for (int j = 0; j <= s2.length(); j++) {
        matrix[j][0] = j;
    }

    // Populate the matrix
    for (int j = 1; j <= s2.length(); j++) {
        for (int i = 1; i <= s1.length(); i++) {
            int cost = s1.charAt(i - 1) == s2.charAt(j - 1) ? 0 : 1;
            int min = Math.min(matrix[j - 1][i] + 1, // Deletion
                    Math.min(matrix[j][i - 1] + 1, // Insertion
                            matrix[j - 1][i - 1] + cost)); // Substitution
            matrix[j][i] = min;
        }
    }

    return matrix[s2.length()][s1.length()];
}

Indeks Persamaan Normal

Setelah jarak edit dikira, indeks persamaan boleh dikira dengan menormalkannya kepada panjang daripada rentetan yang lebih panjang:

// Similarity Index Function
public static double similarityIndex(String s1, String s2) {
    int distance = editDistance(s1, s2);
    String longer = s1.length() > s2.length() ? s1 : s2;
    double similarity = 1.0 - (distance / (double) longer.length());
    return similarity;
}

Penggunaan Contoh:

Untuk menggunakan kaedah ini, anda boleh menggunakannya seperti berikut:

String str1 = "The quick fox jumped";
String str2 = "The fox";
double similarity = similarityIndex(str1, str2);
System.out.println("Similarity Index: " + similarity);

Output:

Similarity Index: 0.70

Ini contoh menunjukkan indeks persamaan 0.7 antara "Musang cepat melompat" dan "The musang".

Secara keseluruhannya, teknik yang diterangkan dalam artikel ini menyediakan cara yang kukuh untuk mengukur persamaan rentetan, membolehkan perbandingan berbilang rentetan yang cekap dan berkesan.

Atas ialah kandungan terperinci Bagaimanakah algoritma Levenshtein boleh digunakan untuk mengira jarak edit dan menentukan persamaan antara dua rentetan di Jawa?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn