猴子第一天摘下N个桃子,当时就吃了一半,还不过瘾,就又多吃了一个。第二天又将剩下的桃子吃掉一半,又多吃了一个。以后每天都吃前一天剩下的一半零一个。到第10天在想吃的时候就剩一个桃子了,问第一天共摘下来多少个桃子?并反向打印每天所剩桃子数。
解题思路:
反向推算
第十天桃子数:1
第九天桃子数:(1+1)x2=4
第八天桃子数:(4+1)x2=10
第七天桃子数:(10+1)x2=22
…
第一天桃子数:(第二天桃子总数+1)x2
有了规律就简单多了,整理一下题中变量:分别是天数(n)、所剩桃子数(num),根据规律,编写代码如下:
执行结果:
第9天所剩桃子4个
第8天所剩桃子10个
第7天所剩桃子22个
第6天所剩桃子46个
第5天所剩桃子94个
第4天所剩桃子190个
第3天所剩桃子382个
第2天所剩桃子766个
第1天所剩桃子1534个
猴子第一天摘了:1534个桃子。
代码:
#include <stdio.h>
int getPeachNumber(n)
{
int num;
if(n==