Rumah >pembangunan bahagian belakang >C++ >Bagaimanakah saya boleh mencari semua kejadian subrentetan dalam rentetan yang lebih besar dalam C#?

Bagaimanakah saya boleh mencari semua kejadian subrentetan dalam rentetan yang lebih besar dalam C#?

Barbara Streisand
Barbara Streisandasal
2024-12-28 22:52:15690semak imbas

How Can I Find All Occurrences of a Substring within a Larger String in C#?

Mencari Semua Kedudukan Subrentetan dalam Rentetan Lebih Besar dalam C#

Apabila bekerja dengan rentetan besar, mencari semua kejadian subrentetan tertentu boleh menjadi penting untuk penghuraian dan analisis data. Artikel ini menangani cabaran mencari semua kejadian sedemikian dan menyimpan indeksnya dalam senarai.

Pernyataan Masalah

Anda mempunyai rentetan besar yang perlu anda analisis. Dalam rentetan ini, anda perlu mengenal pasti dan menyimpan kedudukan setiap kejadian subrentetan tertentu. Mari kita andaikan contoh rentetan ialah "ekstrak"(saya,i-mempunyai banyak. bagi]tanda baca." Anda ingin mencari semua kemunculan subrentetan ini dalam rentetan yang lebih besar dan menambah indeksnya pada senarai.

Resolusi

Kaedah 1:

Kaedah IndexOf dalam C# boleh digunakan untuk mencari kejadian pertama subrentetan Walau bagaimanapun, untuk mencari semua kejadian, kita perlu menggunakan gelung untuk mengulang melalui rentetan dan terus mencari sehingga tiada lagi kejadian ditemui.

Teknik ini boleh. dipertingkatkan dengan menggunakan kaedah sambungan untuk menjadikan kod lebih ringkas Berikut ialah kaedah sambungan contoh:

public static List<int> AllIndexesOf(this string str, string value) {
    if (String.IsNullOrEmpty(value))
        throw new ArgumentException("the string to find may not be empty", "value");
    List<int> indexes = new List<int>();
    for (int index = 0;; index += value.Length) {
        index = str.IndexOf(value, index);
        if (index == -1)
            return indexes;
        indexes.Add(index);
    }
}

Kaedah 2:

Sebagai alternatif, iterator juga boleh digunakan untuk menghasilkan indeks secara berurutan:

public static IEnumerable<int> AllIndexesOf(this string str, string value) {
    if (String.IsNullOrEmpty(value))
        throw new ArgumentException("the string to find may not be empty", "value");
    for (int index = 0;; index += value.Length) {
        index = str.IndexOf(value, index);
        if (index == -1)
            break;
        yield return index;
    }
}

Kedua-dua kaedah ini boleh ditambah dengan mudah pada mana-mana objek rentetan, menjadikannya mudah untuk mencari semua subrentetan positions. Sebagai contoh, baris berikut akan menemui semua kemunculan subrentetan "foo" dalam rentetan "fooStringfooBar":

List<int> indexes = "fooStringfooBar".AllIndexesOf("foo");

Atas ialah kandungan terperinci Bagaimanakah saya boleh mencari semua kejadian subrentetan dalam rentetan yang lebih besar dalam C#?. 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