Golang 切片删除指定元素的几种方法

2026-01-25 10:18:40 | 限时活动 | admin | 2712°c

1.截取法(修改原切片)

这里利用对 slice 的截取删除指定元素。注意删除时,后面的元素会前移,所以下标 i 应该左移一位。

// DeleteSlice1 删除指定元素。

func DeleteSlice1(a []int, elem int) []int {

for i := 0; i < len(a); i++ {

if a[i] == elem {

a = append(a[:i], a[i+1:]...)

i--

}

}

return a

}

2.拷贝法(不改原切片)

这种方法最容易理解,重新使用一个 slice,将要删除的元素过滤掉。缺点是需要开辟另一个 slice 的空间,优点是容易理解,而且不会修改原 slice。

// DeleteSlice2 删除指定元素。

func DeleteSlice2(a []int, elem int) []int {

tmp := make([]int, 0, len(a))

for _, v := range a {

if v != elem {

tmp = append(tmp, v)

}

}

return tmp

}

3.移位法(修改原切片)

3.1 方式一(最优方法)

利用一个下标 index,记录下一个有效元素应该在的位置。遍历所有元素,当遇到有效元素,将其移动到 index 且 index 加一。最终 index 的位置就是所有有效元素的下一个位置,最后做一个截取就行了。这种方法会修改原来的 slice。该方法可以看成对第一种方法截取法的改进,因为每次指需移动一个元素,性能更加。

// DeleteSlice3 删除指定元素。

func DeleteSlice3(a []int, elem int) []int {

j := 0

for _, v := range a {

if v != elem {

a[j] = v

j++

}

}

return a[:j]

}

3.2 方式二

创建了一个 slice,但是共用原始 slice 的底层数组。这样也不需要额外分配内存空间,直接在原 slice 上进行修改。

// DeleteSlice4 删除指定元素。

func DeleteSlice4(a []int, elem int) []int {

tgt := a[:0]

for _, v := range a {

if v != elem {

tgt = append(tgt, v)

}

}

return tgt

}

转自:https://blog.csdn.net/K346K346/article/details/124616633