首頁  >  文章  >  後端開發  >  解密 Golang 陣列求交集的技巧

解密 Golang 陣列求交集的技巧

王林
王林原創
2024-04-03 17:39:011152瀏覽

在 Go 語言中,求數組交集的方法有:使用內建函數 Intersect,適用於已排序數組。使用 map,適用於大型或元素不多的陣列。自訂排序和二分搜索,適用於非常大的數組。具體選擇哪種方法取決於數組大小和元素分佈。

解密 Golang 数组求交集的技巧

解密Go 語言陣列求交集的技巧

在Go 語言中,陣列是儲存同類型元素的有序集合。對數組執行交集操作可以獲得兩個或多個數組中同時存在的元素。以下介紹了不同場景下求交集的幾種實用技巧。

內建函數Intersect

Go 語言提供了sort 套件中的Intersect 函數,可直接求取兩個已排序數組的交集。此函數接收兩個已排序數組作為參數,並傳回一個包含交集元素的新數組。

package main

import (
    "fmt"
    "sort"
)

func main() {
    arr1 := []int{1, 3, 5, 7, 9}
    arr2 := []int{2, 4, 6, 8, 9}

    sort.Ints(arr1)
    sort.Ints(arr2)

    res := sort.Intersect(arr1, arr2)
    fmt.Println(res) // []9
}

對於較小的數組,Intersect 函數是高效且簡潔的解決方案。

使用map

對於大型或元素不多的數組,使用map 進行求交集也是一種有效的方法。透過將一個陣列作為 map 的鍵,可以快速檢查另一個陣列中的元素是否也在 map 中。

package main

import "fmt"

func main() {
    arr1 := []int{1, 3, 5, 7, 9}
    arr2 := []int{2, 4, 6, 8, 9}

    m := make(map[int]bool)
    for _, v := range arr1 {
        m[v] = true
    }

    var res []int
    for _, v := range arr2 {
        if m[v] {
            res = append(res, v)
        }
    }

    fmt.Println(res) // []9
}

自訂排序和二分搜尋

對於非常大的數組,使用自訂排序和二分搜尋演算法求交集可以實現更好的效能。首先對兩個數組進行排序,然後遍歷其中一個數組並對另一個數組進行二分搜索,以查找匹配的元素。

package main

import (
    "fmt"
    "sort"
)

func main() {
    arr1 := []int{1, 3, 5, 7, 9, 11, 13, 15}
    arr2 := []int{2, 4, 6, 8, 9, 10, 12, 14, 16}

    sort.Ints(arr1)
    sort.Ints(arr2)

    res := intersection(arr1, arr2)
    fmt.Println(res) // []9
}

func intersection(a, b []int) []int {
    var res []int
    for _, v := range a {
        idx := sort.SearchInts(b, v)
        if idx >= 0 && b[idx] == v {
            res = append(res, v)
        }
    }
    return res
}

根據陣列大小和元素分佈,選擇最合適的求交集技巧可以最佳化程式碼效能。

以上是解密 Golang 陣列求交集的技巧的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn