最近发现不少小伙伴都对Golang很感兴趣,所以今天继续给大家介绍Golang相关的知识,本文《如何确保地图内的整数数组元素唯一性?》主要内容涉及到等等知识点,希望能帮到你!当然如果阅读本文时存在不同想法,可以在评论中表达,但是请勿使用过激的措辞~
问题内容我有一个字符串和 int 数组的映射,如下所示,正在填充 -
var customerCatalog = make(map[string][]int64)
for ... {
var data = "....."
for _, catalogId := range data.Catalogs {
var ok bool
var keys []int64
var tmp interface{}
cusId := strconv.FormatInt(int64(catalogId), 10)
if tmp, ok = customerCatalog[cusId]; !ok {
keys = []int64{}
} else {
keys = tmp.([]int64)
}
keys = append(keys, data.ProductId)
customerCatalog[cusId] = keys
}
}
这里data.catalogs
是int32数组。 data.productid
是 int64。因此,我需要循环 data.catalogs
数组,并使用每个 data.productid
键的唯一数组值填充我的 customercatalog
映射。
正如你所看到的,我将地图的值作为整数数组,其中可以有重复的值。我想确保映射中特定键的整数数组应具有唯一值。由于 go 不支持泛型,所以我们没有设置,那么我们应该如何处理这种情况?
正确答案
由于 go 不支持泛型,所以我们没有设置
集合通常使用哈希表的键来实现;忽略这些值。
在 go 中,使用 map[int64]bool
。
// Check if an array contains only unique values.
func is_unique(array []int64) bool {
var unique = map[int64]bool{}
for _,v := range(array) {
if unique[v] {
return false
}
unique[v] = true
}
return true
}
// Return a deduplicated array
func uniq(array []int64) []int64 {
var unique = map[int64]bool{}
keys := make([]int64, 1)
for _,v := range(array) {
if _, ok := unique[v]; !ok {
keys = append(keys, v)
unique[v] = true
}
}
return keys
}
本篇关于《如何确保地图内的整数数组元素唯一性?》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于Golang的相关知识,请关注编程网公众号!