Rumah >Java >javaTutorial >Bagaimana Mengira Kejadian Substring dengan Betul dalam Rentetan Java?

Bagaimana Mengira Kejadian Substring dengan Betul dalam Rentetan Java?

DDD
DDDasal
2025-01-04 15:25:40486semak imbas

How to Correctly Count Substring Occurrences in a Java String?

Cara Mencari Bilangan Kejadian Subrentetan dalam Rentetan

Ramai pembangun menghadapi masalah apabila cuba menentukan kekerapan subrentetan kejadian dalam rentetan yang diberikan. Satu kes sedemikian melibatkan algoritma berikut:

String str = "helloslkhellodjladfjhello";
String findStr = "hello";
int lastIndex = 0;
int count = 0;

while (lastIndex != -1) {
    lastIndex = str.indexOf(findStr, lastIndex);

    if (lastIndex != -1)
        count++;

    lastIndex += findStr.length();
}

System.out.println(count);

Mengapa algoritma gagal?

Walaupun berjaya mengenal pasti kejadian pertama "hello" pada indeks 0, algoritma memasuki gelung tidak berkesudahan apabila mencari kejadian berikutnya. Ini kerana selepas kejadian pertama ditemui, lastIndex findStr.length() menjadi sama dengan 5, tetapi hasil "-1" seterusnya yang dikembalikan oleh indexOf() menyebabkan gelung while berulang semula dengan lastIndex masih ditetapkan kepada 0.

Bagaimana untuk menyelesaikan isu ini?

Terdapat beberapa cara untuk menyelesaikan isu ini. Salah satunya ialah menggunakan kaedah carian subrentetan yang berbeza, seperti StringUtils.countMatches() Apache Commons Lang. Berikut ialah contoh:

String str = "helloslkhellodjladfjhello";
String findStr = "hello";

System.out.println(StringUtils.countMatches(str, findStr)); // Outputs 3

Sebagai alternatif, anda boleh mengubah suai algoritma asal untuk mengendalikan kes "-1":

String str = "helloslkhellodjladfjhello";
String findStr = "hello";
int lastIndex = 0;
int count = 0;

while (lastIndex != -1) {
    lastIndex = str.indexOf(findStr, lastIndex);

    if (lastIndex != -1) {
        count++;
        lastIndex += findStr.length();
    } else {
        break; // Exit the loop if no more occurrences are found
    }
}

System.out.println(count); // Outputs 3

Atas ialah kandungan terperinci Bagaimana Mengira Kejadian Substring dengan Betul dalam Rentetan Java?. 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