package utilsv2 func DuplicateRemovalAny[T any, V comparable](ts []T, fn func(t T) V) []T { v := make([]T, 0, len(ts)) tmp := map[V]struct{}{} for i := 0; i < len(ts); i++ { t := ts[i] k := fn(t) if _, ok := tmp[k]; !ok { tmp[k] = struct{}{} v = append(v, t) } } return v } func DuplicateRemoval[T comparable](ts []T) []T { return DuplicateRemovalAny(ts, func(t T) T { return t }) } func DeleteAt[T any](ts []T, index ...int) []T { switch len(index) { case 0: return ts case 1: i := index[0] if len(ts) <= i || len(ts) < -i { return ts } if i < 0 { i = len(ts) + i } return append(ts[:index[0]], ts[index[0]+1:]...) default: tmp := make(map[int]struct{}) for _, i := range index { if i < 0 { i = len(ts) + i } tmp[i] = struct{}{} } v := make([]T, 0, len(ts)) for i := 0; i < len(ts); i++ { if _, ok := tmp[i]; !ok { v = append(v, ts[i]) } } return v } }