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.
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.
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 }
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.
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!