#**
7-33 猴子吃桃问题** (15分)
##一只猴子第一天摘下若干个桃子,当即吃了一半,还不过瘾,又多吃了一个;第二天早上又将剩下的桃子吃掉一半,又多吃了一个。以后每天早上都吃了前一天剩下的一半加一个。到第N天早上想再吃时,见只剩下一个桃子了。问:第一天共摘了多少个桃子?
输入格式:
输入在一行中给出正整数N(1<N≤10)。
输出格式:
在一行中输出第一天共摘了多少个桃子。
输入样例:
3
输出样例:
10
代码如下:
p = 1
n=eval(input())
for i in range(n,1,-1):
p = (p+1) * 2
print§
这个题的题意是很好懂的,意思就是说,假设有m个桃子,一猴子每天吃掉m/2+1个桃子,结果到最后一天的时候,只剩下一个桃子了。
注意,前一天的桃子数和今天的桃子数的关系是
*yesterday=(today+1)2
让你求一开始摘了多少桃子。
重点是range 的用法
举个栗子,range(start, stop, step)
意思是:
start: 计数从 start 开始。默认是从 0 开始。例如range(5)等价于range(0, 5);
stop: 计数到 stop 结束,但不包括 stop。例如:range(0, 5) 是[0, 1, 2, 3, 4]没有5;
**step:**步长,默认为1。例如:range(0, 5) 等价于 range(0, 5, 1)
而for i in range (n,1,-1)的意思是,n表示这些桃子被猴子吃得只剩1个用了n天,1表示今天,-1表示时间渐渐流向今天,所以是-1;
今天剩1个,昨天就剩3个;
昨天剩3个,前天就剩8个;
。。。。。。
最后,就得出第一天到底摘了多少桃子了。