亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

檢查 Go 中的映射是否有重復值

檢查 Go 中的映射是否有重復值

Go
12345678_0001 2023-07-10 10:49:54
考慮下面的地圖mymap := make(map[string]string)mymap["a"] = "one"mymap["b"] = "two"mymap["c"] = "one"如何判斷值是否唯一?一種策略是迭代地圖,創建值的一部分。然后迭代切片以查找重復項。有沒有更好的辦法?
查看完整描述

2 回答

?
蕭十郎

TA貢獻1815條經驗 獲得超13個贊

如果您只需要判斷是否存在重復值,而不需要知道哪些值是重復值或有多少個重復值,則用于跟蹤現有值的最有效結構是具有空結構值的映射。

(為了方便起見,粘貼在下面):

package main


import (

? ? "fmt"

)


func hasDupes(m map[string]string) bool {

? ? x := make(map[string]struct{})


? ? for _, v := range m {

? ? ? ? if _, has := x[v]; has {

? ? ? ? ? ? return true

? ? ? ? }

? ? ? ? x[v] = struct{}{}

? ? }


? ? return false

}


func main() {

? ? mapWithDupes := make(map[string]string)

? ? mapWithDupes["a"] = "one"

? ? mapWithDupes["b"] = "two"

? ? mapWithDupes["c"] = "one"


? ? fmt.Println(hasDupes(mapWithDupes)) // prints true


? ? mapWithoutDupes := make(map[string]string)

? ? mapWithoutDupes["a"] = "one"

? ? mapWithoutDupes["b"] = "two"

? ? mapWithoutDupes["c"] = "three"


? ? fmt.Println(hasDupes(mapWithoutDupes)) // prints false

}


查看完整回答
反對 回復 2023-07-10
?
智慧大石

TA貢獻1946條經驗 獲得超3個贊

func main() {


    m := map[int]int{

        1: 100,

        2: 200,

        3: 100,

        4: 400,

        6: 200,

        7: 700,

    }

    mNew := make(map[int]int)


    for k, v := range m {

        if val, has := mNew[v]; !has {

            mNew[v] = k

        } else {

            fmt.Println(k, m[k], ",", val, m[val])

        }

    }

將映射鍵和值與新映射交換第二個映射不會插入重復鍵,因此您可以找到值


查看完整回答
反對 回復 2023-07-10
  • 2 回答
  • 0 關注
  • 153 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號