1 回答

TA贡献1877条经验 获得超6个赞
这是一个递归示例https://go.dev/play/p/cLm-QHydM37
这导致以下迭代
当长度为 5 时:map[1:5 2:25 3:125 4:625 5:3125]
当长度为 3 时:map[1:3 2:9 3:27 4:0 5:0]
package main
import "fmt"
func main() {
count := map[int]int{1: 0, 2: 0, 3: 0, 4: 0, 5: 0}
// This recursion is based on https://gobyexample.com/recursion
var loopFunc func(current int, data []string)
loopFunc = func(current int, data []string) {
for i := 0; (i < len(data)) && (len(data) != current-1); i++ {
count[current] = count[current] + 1
loopFunc(current+1, data)
}
}
loopFunc(1, make([]string, 5))
fmt.Println(count)
}
我可能没有完全正确的循环逻辑,但这应该是您继续前进的跳板。
- 1 回答
- 0 关注
- 86 浏览
添加回答
举报