问题:猴子第一天摘下N个桃子, 当时就吃了一半,还不过瘾, 就又多吃了一个。第二天又将剩下的桃子吃掉一半, 又多吃了一个。以后每天都吃前一天剩下的一半零一个。 到第10天在想吃的时候就剩一个桃子了, 问第一天共摘下来多少个桃子?
解答: 由于目前只知道猴子第十天剩余的桃子数量为1个,采用逆向思维方式, 故设桃子的剩余数量为x个,则:
-
第十天: , 得到第九天剩余 个, 依次类推,第八天剩余 等。
-
以桃子数量为参考,得到如下公式推导:
第10天:
第9天:
第8天:
第7天:
...
第1天:
总结公式: = ( + 1 ) * 2
-
以剩余桃子数量的函数为参考。得到如下公式推导:
第10天: f(10) = 1
第9天: f(9) = ( f(10) + 1 ) * 2 = 4
第8天: f(8) = ( f(9) + 1 ) * 2 = 10
第7天: f(7) = ( f(8) + 1 ) * 2 = 22
...
第1天: f(1) = ( f(2) + 1 ) * 2 = ?
总结公式: f(n) = ( f(n + 1) + 1 ) * 2
-
Coding。。。
- 循环解决方案(以桃子数量为参考)
#include <stdio.h>
int getPeachNumber() {
int num = 1; // 第10天剩下的桃子数量
for (int n = 9; n >= 1; n--) {
num = (num + 1) * 2;
printf("第%d天所剩桃子%d个\n", n, num);
}
return num;
}
int main() {
int num = getPeachNumber();
printf("猴子第一天摘了:%d个桃子。\n", num);
return 0;
}
- 递归解决方案(以剩余桃子数量的函数为参考)
#include <stdio.h>
int getPeachNumber(int n)
{
int num;
if(n==10)
{
return 1;
}
else
{
num = (getPeachNumber(n+1)+1)*2;
printf("第%d天所剩桃子%d个\n", n, num);
}
return num;
}
int main()
{
int num = getPeachNumber(1);
printf("猴子第一天摘了:%d个桃子。\n", num);
return 0;
}
思考(Thinking)
- 当前循环和递归的实际解决方案,其实是我们所看的问题的视角不同,站在不同的角色去处理不同的数学逻辑。并且可以通过数学推导,得到对应参考的公式,从而解决实际问题。