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

Bagaimana Mengira Kejadian Substring dengan Betul dalam Rentetan Java?

DDD
Lepaskan: 2025-01-04 15:25:40
asal
481 orang telah melayarinya

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);
Salin selepas log masuk

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
Salin selepas log masuk

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
Salin selepas log masuk

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!

sumber:php.cn
Kenyataan Laman Web ini
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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan