Jadual Kandungan
Mengalih keluar Pendua daripada Slices dalam Go
Penyelesaian Berasaskan Gelung Tidak Cekap
Penyelesaian Berasaskan Peta yang Cekap
Perbandingan Prestasi
Kesimpulan
Rumah pembangunan bahagian belakang Golang Bagaimanakah Saya Boleh Mengeluarkan Elemen Pendua dengan Cekap daripada Slices dalam Go?

Bagaimanakah Saya Boleh Mengeluarkan Elemen Pendua dengan Cekap daripada Slices dalam Go?

Dec 18, 2024 pm 06:35 PM

How Can I Efficiently Remove Duplicate Elements from Slices in Go?

Mengalih keluar Pendua daripada Slices dalam Go

Apabila bekerja dengan slice dalam Go, anda mungkin menghadapi situasi di mana anda perlu menapis unsur pendua. Artikel ini meneroka pelbagai pendekatan untuk mencapai perkara ini dalam Go.

Penyelesaian Berasaskan Gelung Tidak Cekap

Teknik yang biasa tetapi tidak cekap ialah mengulangi hirisan dan menyemak pendua menggunakan gelung bersarang. Walaupun kaedah ini berfungsi, ia mempunyai kerumitan masa O(n^2), yang boleh menjadi perlahan untuk kepingan besar.

Penyelesaian Berasaskan Peta yang Cekap

Pendekatan yang lebih cekap menggunakan terbina Go -dalam jenis peta. Berikut ialah dua penyelesaian:

Penyelesaian Generik:

Menggunakan generik (diperkenalkan dalam Go 1.18), anda boleh mencipta fungsi generik yang mengalih keluar pendua untuk sebarang jenis data dengan jenis setanding.

func removeDuplicate[T comparable](sliceList []T) []T {
    allKeys := make(map[T]bool)
    list := []T{}
    for _, item := range sliceList {
        if _, value := allKeys[item]; !value {
            allKeys[item] = true
            list = append(list, item)
        }
    }
    return list
}
Salin selepas log masuk

Penyelesaian Dioptimumkan untuk Rentetan:

Untuk kepingan rentetan, anda boleh mencipta fungsi khusus yang mengoptimumkan carian kunci peta:

func removeDuplicateStr(strSlice []string) []string {
    allKeys := make(map[string]bool)
    list := []string{}
    for _, item := range strSlice {
        if _, value := allKeys[item]; !value {
            allKeys[item] = true
            list = append(list, item)
        }
    }
    return list
}
Salin selepas log masuk

Perbandingan Prestasi

Penyelesaian generik membuktikan menjadi lebih fleksibel tetapi lebih perlahan daripada penyelesaian khusus rentetan. Penandaarasan pada kepingan besar menunjukkan bahawa penyelesaian khusus rentetan adalah jauh lebih pantas.

Kesimpulan

Apabila mengalih keluar pendua daripada kepingan dalam Go, memilih pendekatan yang paling cekap bergantung pada kes penggunaan dan jenis data tertentu . Untuk jenis data kompleks atau kepingan kecil, penyelesaian generik adalah sesuai. Untuk kepingan besar rentetan, penyelesaian khusus rentetan memberikan prestasi optimum.

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mengeluarkan Elemen Pendua dengan Cekap daripada Slices dalam Go?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

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

Tag artikel panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

GO Language Pack Import: Apakah perbezaan antara garis bawah dan tanpa garis bawah? GO Language Pack Import: Apakah perbezaan antara garis bawah dan tanpa garis bawah? Mar 03, 2025 pm 05:17 PM

GO Language Pack Import: Apakah perbezaan antara garis bawah dan tanpa garis bawah?

Bagaimana untuk melaksanakan pemindahan maklumat jangka pendek antara halaman dalam kerangka beego? Bagaimana untuk melaksanakan pemindahan maklumat jangka pendek antara halaman dalam kerangka beego? Mar 03, 2025 pm 05:22 PM

Bagaimana untuk melaksanakan pemindahan maklumat jangka pendek antara halaman dalam kerangka beego?

Bagaimana saya menulis objek dan stub untuk ujian di GO? Bagaimana saya menulis objek dan stub untuk ujian di GO? Mar 10, 2025 pm 05:38 PM

Bagaimana saya menulis objek dan stub untuk ujian di GO?

Bagaimana saya boleh menggunakan alat pengesanan untuk memahami aliran pelaksanaan aplikasi saya? Bagaimana saya boleh menggunakan alat pengesanan untuk memahami aliran pelaksanaan aplikasi saya? Mar 10, 2025 pm 05:36 PM

Bagaimana saya boleh menggunakan alat pengesanan untuk memahami aliran pelaksanaan aplikasi saya?

Bagaimana cara menukar senarai hasil pertanyaan mysql ke dalam slice struktur tersuai dalam bahasa Go? Bagaimana cara menukar senarai hasil pertanyaan mysql ke dalam slice struktur tersuai dalam bahasa Go? Mar 03, 2025 pm 05:18 PM

Bagaimana cara menukar senarai hasil pertanyaan mysql ke dalam slice struktur tersuai dalam bahasa Go?

Bagaimana saya boleh menentukan kekangan jenis tersuai untuk generik di GO? Bagaimana saya boleh menentukan kekangan jenis tersuai untuk generik di GO? Mar 10, 2025 pm 03:20 PM

Bagaimana saya boleh menentukan kekangan jenis tersuai untuk generik di GO?

Bagaimana cara menulis fail dalam bahasa Go dengan mudah? Bagaimana cara menulis fail dalam bahasa Go dengan mudah? Mar 03, 2025 pm 05:15 PM

Bagaimana cara menulis fail dalam bahasa Go dengan mudah?

Bagaimanakah saya menulis tanda aras yang mencerminkan prestasi dunia secara tepat di GO? Bagaimanakah saya menulis tanda aras yang mencerminkan prestasi dunia secara tepat di GO? Mar 10, 2025 pm 05:36 PM

Bagaimanakah saya menulis tanda aras yang mencerminkan prestasi dunia secara tepat di GO?

See all articles