原文鏈接:> https://www.zhoubotong.site/post/95.html
某些業(yè)務(wù)場景可能需要實(shí)現(xiàn)兩個(gè)或者多個(gè)map 的交差并集,一下舉個(gè)簡單的demo, 思路其實(shí)并不復(fù)雜:
package main
import "fmt"
// 并集
func union(m1, m2 map[string]int) map[string]int {
result := make(map[string]int) // 思路:先把其中一個(gè)map 放到新的對象中,把m2中key不存在于本對象中合并即可
for k, v := range m1 {
result[k] = v
}
for k, v := range m2 {
if _, ok := result[k]; !ok {
result[k] = v
}
}
return result
}
// 交集 兩個(gè)map中都存在
func intersection(m1, m2 map[string]int) map[string]int {
result := make(map[string]int) // 思路:優(yōu)先遍歷m1,判斷m2中是否存在相同key,存在則存入新對象
for k, v := range m1 {
if _, ok := m2[k]; ok {
result[k] = v
}
}
return result
}
// 差集 包括第一個(gè)map中存在的鍵值對,但是不包括第二個(gè)map中的鍵值對
func difference(m1, m2 map[string]int) map[string]int {
result := make(map[string]int) // 思路:遍歷m1, 判斷m2中不存在相同key的則存入新對象,即為差集
for k, v := range m1 {
if _, ok := m2[k]; !ok {
result[k] = v
}
}
return result
}
func main() {
m1 := make(map[string]int)
m1["a"] = 11
m1["b"] = 12
m1["c"] = 13
m2 := make(map[string]int)
m2["a"] = 11
m2["c"] = 13
fmt.Println("并集:", union(m1, m2))
fmt.Println("交集:", intersection(m1, m2))
fmt.Println("差集:", difference(m1, m2))
}
輸出:文章來源:http://www.zghlxwxcb.cn/news/detail-422342.html
[Running] go run "/media/uos/G/web/demo/main.go"
并集: map[a:11 b:12 c:13]
交集: map[a:11 c:13]
差集: map[b:12]
代碼中有簡單說明,不難看出實(shí)現(xiàn)過程其實(shí)比較簡單。文章來源地址http://www.zghlxwxcb.cn/news/detail-422342.html
到了這里,關(guān)于go 計(jì)算map 差集、并集、交集的文章就介紹完了。如果您還想了解更多內(nèi)容,請?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!