Rumah >pembangunan bahagian belakang >C++ >Bagaimanakah saya dapat menghapuskan pendua dari array C#?

Bagaimanakah saya dapat menghapuskan pendua dari array C#?

Susan Sarandon
Susan Sarandonasal
2025-01-25 11:56:13573semak imbas

How Can I Efficiently Remove Duplicates from a C# Array?

Menghapuskan Pendua daripada Tatasusunan C# dengan Cekap

Pemprosesan tatasusunan data selalunya memerlukan penghapusan entri pendua. C# menawarkan beberapa kaedah untuk mencapai ini; mari kita periksa teknik yang biasa dan berkesan.

Kaedah Susunan Sementara

Pendekatan mudah melibatkan tatasusunan sementara:

  1. Lelaran melalui tatasusunan sumber, membandingkan setiap elemen dengan tatasusunan sementara.
  2. Jika unsur wujud dalam tatasusunan sementara, abaikan unsur tersebut.
  3. Jika tidak, tambahkannya pada tatasusunan sementara.

Contoh Ilustrasi:

<code class="language-csharp">int[] originalArray = { 1, 2, 3, 3, 4 };
int[] tempArray = new int[originalArray.Length];

int index = 0;
for (int i = 0; i < originalArray.Length; i++)
{
    bool isDuplicate = false;
    for (int j = 0; j < index; j++)
    {
        if (originalArray[i] == tempArray[j])
        {
            isDuplicate = true;
            break;
        }
    }
    if (!isDuplicate)
    {
        tempArray[index++] = originalArray[i];
    }
}

// tempArray now contains the unique elements</code>

Walaupun mudah, kecekapan kaedah ini berkurangan dengan tatasusunan yang lebih besar disebabkan oleh gelung bersarang.

Penyelesaian Alternatif

Di luar kaedah tatasusunan sementara, pertimbangkan alternatif ini:

  • LINQ: Manfaatkan kaedah Distinct() LINQ untuk penyelesaian yang ringkas dan deklaratif.
  • HashSet: Gunakan HashSet, struktur data yang dioptimumkan untuk menyimpan elemen unik, untuk prestasi unggul dengan set data yang besar.

Pendekatan optimum bergantung pada keperluan dan had khusus aplikasi anda.

Atas ialah kandungan terperinci Bagaimanakah saya dapat menghapuskan pendua dari array 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