最佳化Go 切片中的去重
簡介
遇到包含重複元素的資料集是很常見,尤其是涉及大量資料收集的場景。刪除這些重複項以獲得唯一值對於各種操作至關重要。在 Go 中,要實現這一點需要高效的演算法來最小化時間和空間複雜度。本文探討了從字串或整數切片中刪除重複項的綜合解決方案。
通用實作
第一種方法利用泛型,在 Go v1.18 及更高版本中可用,處理任何類似類型 (T) 的切片。它利用映射來追蹤遇到的值,確保僅將唯一元素附加到結果切片中。
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 }
字串特定最佳化
對於僅包含的切片字串,有一個使用 make 函數的更最佳化的解決方案。它使用輸入切片的大小初始化映射,從而無需動態調整大小和潛在的性能損失。
func removeDuplicateStr(strSlice []string) []string { allKeys := make(map[string]bool, len(strSlice)) list := []string{} for _, item := range strSlice { if _, value := allKeys[item]; !value { allKeys[item] = true list = append(list, item) } } return list }
整數特定最佳化
類似於字串特定的方法,用於整數切片的專用函數可以利用 make函數來增強
func removeDuplicateInt(intSlice []int) []int { allKeys := make(map[int]bool, len(intSlice)) list := []int{} for _, item := range intSlice { if _, value := allKeys[item]; !value { allKeys[item] = true list = append(list, item) } } return list }
用法
無論切片類型如何,這些函數的用法都很簡單。只需將輸入切片作為參數傳遞,您就會收到一個僅包含唯一元素的切片。
cities := []string{"Mumbai", "Delhi", "Ahmedabad", "Mumbai", "Bangalore", "Delhi", "Kolkata", "Pune"} uniqueCities := removeDuplicate(cities) fmt.Println(uniqueCities) // [Mumbai Delhi Ahmedabad Bangalore Kolkata Pune]
以上是如何高效率去除Go切片中的重複元素?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本文演示了創建模擬和存根進行單元測試。 它強調使用接口,提供模擬實現的示例,並討論最佳實踐,例如保持模擬集中並使用斷言庫。 文章

本文探討了GO的仿製藥自定義類型約束。 它詳細介紹了界面如何定義通用功能的最低類型要求,從而改善了類型的安全性和代碼可重複使用性。 本文還討論了局限性和最佳實踐

本文使用跟踪工具探討了GO應用程序執行流。 它討論了手冊和自動儀器技術,比較諸如Jaeger,Zipkin和Opentelemetry之類的工具,並突出顯示有效的數據可視化

本文討論了GO的反思軟件包,用於運行時操作代碼,對序列化,通用編程等有益。它警告性能成本,例如較慢的執行和更高的內存使用,建議明智的使用和最佳

本文討論了GO中使用表驅動的測試,該方法使用測試用例表來測試具有多個輸入和結果的功能。它突出了諸如提高的可讀性,降低重複,可伸縮性,一致性和A

本文提倡使用襯里和靜態分析工具來增強GO代碼質量。 它詳細詳細介紹了工具選擇(例如Golangci-lint,Go Vet),工作流集成(IDE,CI/CD)以及對警告/錯誤的有效解釋以改善COD


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

禪工作室 13.0.1
強大的PHP整合開發環境

記事本++7.3.1
好用且免費的程式碼編輯器

Atom編輯器mac版下載
最受歡迎的的開源編輯器

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。