蓝桥等考python12级(山洞寻宝)

山洞寻宝
题目描述:
有n个宽度为1、并排的山洞,每个山洞里都藏着金币。
山洞前有一扇宽度为3的石门,被石门挡住的山洞不能进入。你有一次施展魔法的机会,可以让石门平移到任意连续的3个山洞前。石门只能平移一
次,平移前不能进入山洞。
已知每个洞里藏着的金币数量,问你最多能拿到多少个金币。
例如,有5个山洞,每个山洞的金币数量是7,2,12,5,3。

你有3种拿金币的方法:
1.让石门移动到最左边,拿右边两个山洞的金币,共8个;
2.让石门移动到正中间,拿两头山洞的金币,共10个;
3.让石门移动到最右边,拿左边两个山洞的金币,共9个;
你最多能拿到10个金币。
输入:
第一行一个正整数,为山洞数量n(4<=n<=20);
第二行,按字符串形式输入n个正整数(大小在1~20范围内),相邻两个正整数用一个空格分隔。按从左到右的顺序,每个正整数表示一个山洞里藏着
的金币数量。
提示:
s = input() #输入一个字符串,赋值给s
a = s.split(' ') #将字符串s按空格拆分,保存到列表a中
lis = [int(i) for i in a] #将列表a的元素转换成整数,保存到列表lis中
输出:
一个整数,为你最多能拿到金币的数量。
输入样例1:
5
7 2 12 5 3

输出样例1:
10


输入样例2:
7
4 18 2 10 7 16 1
输出样例2:
39

参考答案:

#参考程序1:
n = int(input())
s = input()
a = s.split(' ')
lis = [int(i) for i in a]
ans = 0
for i in range(n - 3): #遍历石门可能的位置,i是石门左端的位置坐标
    ans = max(ans, sum(lis) - sum(lis[i : i + 3])) #进不去的山洞有3个,求和,再用总数减,打擂台求最大
print(ans)
#参考程序2(校验用):
n = int(input())
s = input()
a = s.split(' ')
lis = [int(i) for i in a]
lis.insert(0, 0)
Pre = [0] * (n + 1) #Pre[i]是列表前i项和
Coin = [0] * (n + 1) #Coin[i]是以i结尾的连续3个山洞的金币数量
for i in range(1, n + 1):
    Pre[i] = Pre[i - 1] + lis[i]
for i in range(3, n + 1):
    Coin[i] = Pre[i] - Pre[i - 3]
print(sum(lis) - min(Coin[3:]))

  • 27
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值