Rumah > Java > javaTutorial > Bagaimanakah Saya Boleh Mengira Kejadian Subrentetan dengan Amanah dalam Rentetan?

Bagaimanakah Saya Boleh Mengira Kejadian Subrentetan dengan Amanah dalam Rentetan?

DDD
Lepaskan: 2024-12-14 06:27:10
asal
956 orang telah melayarinya

How Can I Reliably Count Substring Occurrences in a String?

Kira Kejadian Subrentetan dalam Rentetan

Apabila cuba memastikan kejadian subrentetan dalam rentetan, isu biasa timbul apabila carian algoritma gagal ditamatkan. Untuk membetulkannya, adalah penting untuk menangani perkara berikut:

Memahami Isu

Pertimbangkan contoh yang disediakan, di mana matlamatnya adalah untuk mengira kejadian "hello" dalam rentetan "helloslkhellodjladfjhello." Algoritma secara berulang mencari subrentetan menggunakan kaedah indexOf. Walau bagaimanapun, ia melaraskan lastIndex secara berperingkat mengikut panjang subrentetan, menghasilkan gelung tak terhingga.

Penyelesaian Boleh Dipercayai

Untuk mengatasinya, seseorang boleh menggunakan countMatches kaedah daripada Apache Commons Lang. Fungsi pratakrif ini mengira kejadian subrentetan dengan tepat, seperti yang ditunjukkan dalam kod di bawah:

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

System.out.println(StringUtils.countMatches(str, findStr));
Salin selepas log masuk

Ini menghasilkan kiraan dijangka 3.

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mengira Kejadian Subrentetan dengan Amanah dalam Rentetan?. 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