type MenuItem struct { Id int32 Type string SortOrder int8 CategoryId int32 Children []*MenuItem }如果你有這個(gè)結(jié)構(gòu),并且你有一片[]MenuItem. 我只想檢索一個(gè)帶有CategoryId值的切片。這看起來(lái)像一個(gè)遞歸用例,Children但基于切片的附加函數(shù)的工作方式,它看起來(lái)有點(diǎn)棘手。有任何想法嗎?你會(huì)怎么做?最終結(jié)果應(yīng)該是一片[]int32:[11, 1900, 12, 1300,...., 2090]
1 回答

楊__羊羊
TA貢獻(xiàn)1943條經(jīng)驗(yàn) 獲得超7個(gè)贊
讓我們append為您完成艱苦的工作,處理內(nèi)存擴(kuò)展,并在每個(gè)遞歸步驟中返回其結(jié)果:
func traverse(m *MenuItem) (r []int32) {
if m == nil {
return
}
r = append(r, m.CategoryId)
for _, c := range m.Children {
r = append(r, traverse(c)...)
}
return
}
https://go.dev/play/p/8d0cyPMV0r6
- 1 回答
- 0 關(guān)注
- 154 瀏覽
添加回答
舉報(bào)
0/150
提交
取消