1 Star 0 Fork 0

码布什/go工具库

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
ArrayUtil.go 907 Bytes
一键复制 编辑 原始数据 按行查看 历史
zhengqiuyun 提交于 2023-03-08 21:08 . 数组排重可空和不可空添加
package util
import "reflect"
func AppendDeduplicateCanNull[T comparable](slice []T, elems T) []T {
if !ArrayContains(slice, elems) {
slice = append(slice, elems)
}
return slice
}
func AppendDeduplicate[T comparable](slice []T, elems T) []T {
if !reflect.ValueOf(&elems).Elem().IsZero() && !ArrayContains(slice, elems) {
slice = append(slice, elems)
}
return slice
}
func ArrayContains[T comparable](array []T, e T) bool {
for _, v := range array {
if v == e {
return true
}
}
return false
}
func DifferenceSet[K comparable](a1, a2 []K) (d1, d2 []K) {
var vMap = map[K]*int{}
for _, v1 := range a1 {
vMap[v1] = Addr[int](1)
}
for _, v2 := range a2 {
if vMap[v2] == nil {
vMap[v2] = Addr[int](2)
} else {
vMap[v2] = Addr[int](0)
}
}
for k, v := range vMap {
if *v == 1 {
d1 = append(d1, k)
} else if *v == 2 {
d2 = append(d2, k)
}
}
return d1, d2
}
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Go
1
https://gitee.com/manoshi/go-util.git
git@gitee.com:manoshi/go-util.git
manoshi
go-util
go工具库
v0.0.83

搜索帮助