代码拉取完成,页面将自动刷新
package api
import (
"reflect"
"slices"
"sort"
)
// SliceSort slice排序
func SliceSort[S ~[]E, E any](slice S, less func(a, b E) bool) {
sort.Slice(slice, func(i, j int) bool {
a := slice[i]
b := slice[j]
return less(a, b)
})
}
// SliceUnique sorts the slice pointed by the provided pointer given the provided
// less function and removes repeated elements.
// The function panics if the provided interface is not a pointer to a slice.
func v1SliceUnique[S ~[]E, E any](slicePtr *S, less func(i, j int) bool) {
v := reflect.ValueOf(slicePtr).Elem()
if v.Len() <= 1 {
return
}
sort.Slice(v.Interface(), less)
i := 0
for j := 1; j < v.Len(); j++ {
if !less(i, j) {
continue
}
i++
v.Index(i).Set(v.Index(j))
}
i++
v.SetLen(i)
}
func SliceUnique[S ~[]E, E any](slice S, compare func(a E, b E) int) S {
//v := reflect.ValueOf(&slice).Elem()
//slices.SortFunc()
slices.SortFunc(slice, compare)
s := slices.CompactFunc(slice, func(a E, b E) bool {
return compare(a, b) == 0
})
return s
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。