Golang 递归实现猴子吃桃问题
问题:
猴子吃桃问题:猴子第一天摘下若干个桃子,当即吃了一半,还不过瘾,又多吃了一个,
第二天早上又将剩下的桃子吃掉一半,又多吃了一个。以后每天早上都吃前一天剩下的一半零一个。
到第10天早上想再吃时,见只剩下一个桃子了。求第一天共摘多少个桃子?
- 分析 :

- 代码实现
package mainimport "fmt"func main() {var s int64 = eatPeach(4)fmt.Println(s)
}func eatPeach(n int64) int64 {if n > 10 || n < 1 {fmt.Println("输入数据有误,请重新输入")}if n == 10 {return 1} else {return (eatPeach(n+1) + 1) * 2}
}
- 画图分析

本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!
