猴子吃桃问题:
猴子第一天摘下若干个桃子,当即吃了一半,还不瘾,又多吃了一个
第二天早上又将剩下的桃子吃掉一半,又多吃了一个。
以后每天早上都吃了前一天剩下的一半零一个。
到第10天早上想再吃时,见只剩下一个桃子了。求第一天共摘了多少。
解题思路:
典型的递归算法问题,递归的出口天数等于1,递归的规律每一天的桃子数量都是后一天的数量加1在乘2。
day10→1
day9→(day10+1)*2=4
day8→(day9+1)*2=10
…
代码实现:
package 阶段训练;
public class Demo12 {
public static void main(String[] args) {
/*猴子吃桃问题:
猴子第一天摘下若干个桃子,当即吃了一半,还不瘾,又多吃了一个
第二天早上又将剩下的桃子吃掉一半,又多吃了一个。
以后每天早上都吃了前一天剩下的一半零一个。
到第10天早上想再吃时,见只剩下一个桃子了。求第一天共摘了多少。*/
int count = getCount(1);
System.out.println(count);
}
public static int getCount(int day) {
if (day <= 0 || day > 10) {
System.out.println("天数错误");
return -1;
}
//递归出口
if (day == 10) {
return 1;
}
//规律
return (getCount(day + 1) + 1) * 2;
}
}
运行效果图: