|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
这是第九讲最后一题
相传国际象棋是古印度舍罕王的宰相达依尔发明的。
舍罕王十分喜爱国际象棋,便决定让宰相自己选择何种赏赐。这位聪明的宰相指着 8×8 共 64 格的象棋棋盘说:陛下,请您赏给我一些麦子吧。就在棋盘的第 1 格中放 1 粒,第 2 格放 2 粒,第 3 格放 4 粒,以后每一格都比前一格增加一倍,依此放完棋盘上 64 格,我就感激不尽了……
舍罕王听了达依尔这个“小小”的要求,便让人扛来一袋麦子,他要兑现许诺。结果,在给达依尔发放麦子时,舍罕王发现他要给达依尔的麦子比自己想象的要多得多,一袋麦子是远远不够的……
请编程计算舍罕王应该给达依尔多少粒麦子?
考虑到大家还没有学习过循环语句,这里小甲鱼帮大家把超纲的代码写好了,你们只需要按照提示,将附件( wheat.zip (354 Bytes, 下载次数: 15443) )中的代码补充完整即可实现。
提示:请将代码中的 # 文字注释 # 替换为 你的代码,# 也要记得去掉哦~hkJt_
自己写的时候感觉还行,看了答案之后,自己都看不懂自己写的是什么意思了,代码可以执行,只是答案不一样,谁能拯救一下,会设最佳答案的!
i = 1
s = 1
while i <= 64:
# 请计算每一个格子的麦子数,并将其赋值给 wheats 变量#
wheats = int(s)
s = s + wheats
i = i + 1
s = 2 * s
print("舍罕王应该给达依尔", s, "粒麦子!")
【代码1】:
- d = 1
- s = 1
- for i in range(63) :
- d = d * 2
- s = s + d
- print("舍罕王应该给达依尔", s , "粒麦子!")
复制代码
【代码2】:
- d = [1]
- for i in range(63) :
- d . append(d[-1] * 2)
- print("舍罕王应该给达依尔", sum(d) , "粒麦子!")
复制代码
|
|