蓝桥等考python12级(分蛋糕)

分蛋糕

题目描述:一块长方体蛋糕被分成了n小块,每小块上都有草莓,如下图所示。

你只能从这块长方体蛋糕中,拿走连续的3小块。
已知每小块蛋糕上的草莓数量,请计算你最多能拿到几颗草莓。
输入:
第一行一个正整数,为蛋糕被分成的小块数量n(4<=n<=20);
第二行,按字符串形式输入n个正整数(大小在1~20范围内),相邻两个正整数用一个空格分隔,每个正整数表示一小块蛋糕上的草莓数量。
提示:
s = input() #输入一个字符串,赋值给s
a = s.split(' ') #将字符串s按空格拆分,保存到列表a中
lis = [int(i) for i in a] #将列表a的元素转换成整数,保存到列表lis中
输出:
一个正整数,表示你拿连续的3小块蛋糕,最多能得到的草莓总数。
输入样例:
7
2314212
输出样例:
8

参考答案:

#参考程序1:
n = int(input())
s = input()
a = s.split(' ')
lis = [int(i) for i in a]
ans = 0
for i in range(n - 3 + 1): #取长度为3的子数组
    ans = max(ans, sum(lis[i : i + 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项和
ans = [0] * (n + 1) #ans[i]是以i结尾的连续3块蛋糕的草莓数量
for i in range(1, n + 1):
    Pre[i] = Pre[i - 1] + lis[i]
for i in range(3, n + 1):
    ans[i] = Pre[i] - Pre[i - 3]
print(max(ans))

  • 4
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
蓝桥杯是一项程序设计竞赛,为初赛和决赛两个阶段。针对Python试,我认为生需要具备以下几方面的准备。 首先,对于Python的基础知识,生需要掌握Python语言的语法、数据类型、运算符、流程控制语句等基本概念和用法。此外,还需要了解Python的常用内置函数和标准库,比如字符串处理、列表操作、文件读写等。 其次,生需要熟悉Python的面向对象编程(OOP)特性,掌握类和对象、封装、继承和多态等相关知识。此外,还需要了解Python中的装饰器、迭代器和生成器等高特性。 第三,生需要具备一定的算法和数据结构的基础。比如掌握常用的排序算法、查找算法等,了解线性结构(如数组、列表、栈、队列)和非线性结构(如树、、堆等)的基本概念和应用场景。 此外,生还需要具备一定的实战经验和编程能力。可以通过参加一些编程实践和项目开发来提升自己的实际操作能力,例如编写一些小的Python应用程序或解决一些实际问题。 最后,生还应该注重综合能力的培养。在备过程中,要注重培养自己的逻辑思维能力、问题析能力和编程的灵活性,这样在比赛中才能更好地应对各种难题。 总而言之,蓝桥杯程序设计竞赛对Python试的要求较高,生需要具备扎实的基础知识、熟练的编程技巧以及一定的实战经验和综合能力。通过不断的学习和实践,相信生能够顺利通过蓝桥杯Python试。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值