Python

#**

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个;
。。。。。。
最后,就得出第一天到底摘了多少桃子了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值