4 回答

TA贡献1909条经验 获得超7个赞
要使用从索引切片检索到的索引值创建新的数据切片,必须迭代索引切片并将索引切片作为数据切片传递。下面是具有此逻辑的代码valueindex
package main
import (
"fmt"
)
func main() {
indexes := []uint8{1, 2, 3}
data := []string{"0s", "1s", "2s", "3s"}
var newData []string
fmt.Println(data)
fmt.Println(indexes)
for _, v2 := range indexes {
newData = append(newData, data[v2])
}
fmt.Println(newData)
}
输出:
[0s 1s 2s 3s]
[1 2 3]
[1s 2s 3s]

TA贡献1804条经验 获得超2个赞
请注意 - 您的索引切片是类型 - 这很好,但限制为最大长度为256的切片。这可能是设计使然,但只是需要注意的事情。[]uint8
这里使用的其他解决方案 - 这对于小切片来说很好。但一般来说,在处理切片时,如果您知道最终的切片长度,最好预先分配并直接写入索引,以避免可能执行多次重新分配:appendappend
func correlate(vs []string, is []uint8) (s []string) {
s = make([]string, len(is)) // pre-allocate results length - to avoid using append
for j, i := range is {
s[j] = vs[i]
}
return
}
https://play.golang.org/p/Et2VyoZzo59

TA贡献1824条经验 获得超8个赞
下面是一个通用解决方案,它仅检索匹配的元素,如果超出范围,则丢弃。https://play.golang.org/p/34vQnNh0jd4
func getElementsByIndexes(data []string, indexes []uint8) []string {
res := make([]string, 0)
l := len(data)
for _, v := range indexes {
// discard if out of range
if int(v) >= l {
continue
}
res = append(res, data[int(v)])
}
return res
}

TA贡献1803条经验 获得超3个赞
我来到了这个非常简单的解决方案:
func filterByIndexes(sl []string, ind []int)[]string{
var filteredSlice []string
for index := range ind{
// you may want to check for index out of range :)
filteredSlice = append(filteredSlice, sl[index])
}
return filteredSlice
}
如前所述,您可能希望检查索引是否超出范围!
- 4 回答
- 0 关注
- 116 浏览
添加回答
举报