


Bagaimanakah Saya Boleh Mengeluarkan Elemen Pendua dengan Cekap daripada Slices dalam Go?
Dec 18, 2024 pm 06:35 PMMengalih 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 }
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 }
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!

Artikel Panas

Alat panas Tag

Artikel Panas

Tag artikel panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

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 saya menulis objek dan stub untuk ujian di GO?

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 saya boleh menentukan kekangan jenis tersuai untuk generik di GO?

Bagaimana cara menulis fail dalam bahasa Go dengan mudah?

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