3 回答
TA贡献1845条经验 获得超8个赞
只需将切片切片 until idx,跳过count元素并将其余元素附加到第一次切片的结果中:
func removeRange(hashCode []string, idx int, count int) []string {
return append(hashCode[:idx], hashCode[idx+count:]...)
}
测试它:
s := []string{"0", "1", "2", "3", "4", "5"}
fmt.Println(s)
s = removeRange(s, 1, 2)
fmt.Println(s)
哪些输出(在Go Playground上尝试):
[0 1 2 3 4 5]
[0 3 4 5]
注意:上述实现不检查索引是否有效(是否在范围内)。如果没有,代码可能会恐慌。如果需要,请添加必要的检查。
注意#2:上述实现修改了传入切片的元素,返回的切片将共享参数的后备数组。如果你想避免这种情况,如果你想保持输入不变并为结果分配一个新切片,那么这样做:
func removeRange(hashCode []string, idx int, count int) []string {
result := make([]string, 0, len(hashCode)-count)
result = append(result, hashCode[:idx]...)
result = append(result, hashCode[idx+count:]...)
return result
}
在Go Playground上试试这个。
TA贡献1725条经验 获得超7个赞
在 golang 中,您根本不需要为此提供方法或函数。Go 切片可以在适当位置进行子切片和附加,这就是您可以快速轻松地从任何切片中删除子集的方法。
假设您要删除 2 个元素,从索引 2 开始,您只需编写:
Sub := append(original [:2], original [4:]...)
这是如何工作的:
original[:2]
创建从 0 开始的子切片,长度为 2 个元素(因此索引 0 和 1)append
因为对于第一部分,我们要添加切片的其余部分,减去我们要跳过/删除的范围original[4:]
创建另一个子切片,这次从索引 4 开始,并在任何original
结束处结束。就像我们没有在第一个子切片中明确提到 0 作为起点一样,通过在此处不指定元素的数量,golang 将仅包含切片中的所有剩余元素。...
因为append
是一个可变参数函数(内置,但你明白了),我们需要传入我们想要附加的每个元素作为新参数。...
运算符扩展子切片并将每个元素作为单独的参数传入。
因为我们将新切片分配给了新变量,original
将保持不变,所以如果要覆盖切片,只需将其分配给相同的变量即可。
注意我是在手机上写的,所以标记和代码可能不太正确,但这至少应该回答你的问题
TA贡献1900条经验 获得超5个赞
我已经使用//注释解释了代码,如果没有注释,代码是不言自明的。
package main
import (
"fmt"
"os"
)
func RemoveRange(s []string, index, count int) []string {
sLen := len(s)
// Similar semantics to match (similar) the behavior of
// C# implementation
switch {
case index < 0, count < 0: // arguments are not valid
fmt.Fprintln(os.Stderr, "error: argument out of range error")
return s
case index+count-1 >= sLen: // range results in exceeding the limit
fmt.Fprintln(os.Stderr, "error: argument error")
return s
}
// Create a slice p and pre-allocate the size required
// to store the resultant slice after removing range.
// Result := s[:] -> s[:index] + s[index+count:]
// Remove := s[index:index+count-1]
p := make([]string, 0, sLen-count)
p = append(p, s[:index]...)
p = append(p, s[index+count:]...)
return p
}
func main() {
s := []string{"0", "1", "2", "3", "4", "5"}
fmt.Println(s)
r := RemoveRange(s, 1, 3)
fmt.Println(r)
}
输出:
[0 1 2 3 4 5]
[0 4 5]
- 3 回答
- 0 关注
- 133 浏览
添加回答
举报