1 Star 0 Fork 0

瑞哥/util

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
Compare.go 2.59 KB
一键复制 编辑 原始数据 按行查看 历史
瑞哥 提交于 2023-03-04 23:26 . 更新到go1.20.x
package rtool
import (
"fmt"
"sync"
)
type IntUintString interface {
~int8 | ~int16 | ~int32 | ~int64 |
~uint8 | ~uint16 | ~uint32 | ~uint64 |
~string
}
// CompareIntersection 切片交集,返回 src 中存在并且 tar 也存在的。
func CompareIntersection[T IntUintString](src []T, tar []T) []T {
var rt = make([]T, 0, 1024)
var tempMap = sync.Map{}
for j := 0; j < len(tar); j++ {
tempMap.Store(fmt.Sprint(tar[j]), byte(1))
}
for i := 0; i < len(src); i++ {
if _, ok := tempMap.Load(fmt.Sprint(src[i])); ok {
rt = append(rt, src[i])
}
}
return rt
}
// CompareSubtractive 切片减集,返回 src 中存在并且 tar 中不存在的。
func CompareSubtractive[T IntUintString](src []T, tar []T) []T {
var rt = make([]T, 0, 1024)
var tempMap = sync.Map{}
for j := 0; j < len(tar); j++ {
tempMap.Store(fmt.Sprint(tar[j]), byte(1))
}
for i := 0; i < len(src); i++ {
if _, ok := tempMap.Load(fmt.Sprint(src[i])); false == ok {
rt = append(rt, src[i])
}
}
return rt
}
// CompareDifference 切片差集,返回先除去 src 中存在 tar 中也存在的,然后合并剩余的 src 和 tar 返回。
func CompareDifference[T IntUintString](src []T, tar []T) []T {
var rt = make([]T, 0, 1024)
temp := CompareIntersection(src, tar)
var tempMap = sync.Map{}
for _, d := range temp {
tempMap.Store(fmt.Sprint(d), byte(1))
}
for i := 0; i < len(src); i++ {
if _, ok := tempMap.Load(fmt.Sprint(src[i])); false == ok {
rt = append(rt, src[i])
}
}
for i := 0; i < len(tar); i++ {
if _, ok := tempMap.Load(fmt.Sprint(tar[i])); false == ok {
rt = append(rt, tar[i])
}
}
return rt
}
// CompareUnion 切片并集,返回合并 src 和 tar ,然后去重的结果。
func CompareUnion[T IntUintString](src []T, tar []T) []T {
var rt = make([]T, 0, 1024)
var tempMap = sync.Map{}
for i := 0; i < len(src); i++ {
if _, ok := tempMap.Load(fmt.Sprint(src[i])); ok {
continue
}
tempMap.Store(fmt.Sprint(src[i]), byte(1))
rt = append(rt, src[i])
}
for i := 0; i < len(tar); i++ {
if _, ok := tempMap.Load(fmt.Sprint(tar[i])); ok {
continue
}
tempMap.Store(fmt.Sprint(tar[i]), byte(1))
rt = append(rt, tar[i])
}
return rt
}
// BinSearch 二分查找法,查找前,arr必须先按照从小到大排序
// 找到了,返回对应的下标;没有找到,返回-1
func BinSearch[T IntUintString](arr []T, value T) int {
length := len(arr)
left := 0
right := length - 1
for i := 0; i < length; i++ {
er := (left + right) / 2
if value > arr[er] {
left = er + 1
} else if value < arr[er] {
right = er - 1
} else {
return er
}
}
return -1
}
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Go
1
https://gitee.com/ruige_fun/util.git
git@gitee.com:ruige_fun/util.git
ruige_fun
util
util
v0.0.44

搜索帮助