题目:猴子吃桃问题:猴子第一天摘下若干个桃子,当即吃了一半,还不瘾,又多吃了一个第二天早上又将剩下的桃子吃掉一半,又多吃了一个。
以后每天早上都吃了前一天剩下的一半零一个。到第10天早上想再吃时,见只剩下一个桃子了。求第一天共摘了多少。
一.反向思维
int main()
{
int i = 1;
int j = 1;
for (j = 10; j > 1;j --)
{
i++;
i = 2 * i;
}
printf("第一天摘了%d个桃子", i);
system("pause");
}
二.正向求解
#include <stdio.h>
main()
{
int day, x1, x2;
day = 9;
x2 = 1;
while (day>0)
{
x1 = (x2 + 1) * 2;/*第一天的桃子数是第2天桃子数加1后的2倍*/
x2 = x1;
day--;
}
printf("第一天摘了%d个桃子\n", x1);
system("pause");
}