当前位置: 首页 > article >正文

【蓝桥杯青少组】第十五届省赛python(2024)

选择题做得飞快。编程题被绊住了...
第四题 熟悉 等差数列求和公式即可,无需赘述
第五题 果然是贪心算法,之前强化训练了一天,看来效果还是不够。

题目简述

浇水
n棵植物编号i=1-n,所需浇水w[i]
每次连续浇L棵,每棵1份水,重复浇多余的排水。
问,最少需要浇多少次,共排水多少量?
输入:
n=4; L=3; w=[1,1,3,2]
输出
3,2

思路

 贪心算法
# 先找到最高max(w)
# 再算前后L个范围内连续L个w[j]之和,取最高段[ind,ind+L]浇水, 
# 因一,最高优先,早晚要浇
#    二,浇水每次L,需水固定,最少浇水次数->最少浇水量->最少排水量->sum(range(ind,ind+L))最大

代码

import random
n=random.randint(30,50);L=random.randint(n//5,n//4+1)
w=[random.randint(1,10) for _ in range(n)]
# n=4; L=3; w=[1,1,3,2] # 输入。输出应为 3,2
print(n,L); print(w,"\n")

# 贪心算法
# 先找到最高max(w)
# 再算前后L个范围内连续L个之和最高, 
# 因一,最高优先,早晚要浇
#	二,浇水每次L,需水固定,最少浇水次数->最少浇水量->最少排水量->sum(range(ind,ind+L))最大
need=sum(w)
if n<=L:
	cnt=max(w); ma=0  # 直接全浇水
else:
	cnt=0; ma=max(w)
while(ma>0):
	i=w.index(ma) # 最高点的序号
	# 找到包括i的浇水范围 range(iB,iE)
	iB=i-L+1 if i-L+1>0 else 0 
	iE=i+L if i+L<n else n 
	# 计算可用范围段,连续L个数的sum
	ws=[sum(w[j:j+L]) for j in range(iB,iE-L+1) if j+L<=n]
	# 取max(sum)段浇水,注意len(ws)的情况,即
	ind=ws.index(max(ws))+iB if len(ws)>0 else iE-L
	for j in range(ind,ind+L): w[j]=w[j]-1 if w[j]>0 else 0
	cnt+=1; ma=max(w); print(cnt,w)
print(cnt,cnt*L-need)

小结

回顾这类贪心算法问题

原始版:鸡兔同笼,假设所有头都是鸡的,多一只兔,就多2条腿

基础版:吃奶酪,甲乙口味不同,吃不同奶酪给分不同,已知a吃k个,求最高分?
假设都给乙吃,然后降序排 a[i]-b[i], 取前k个,累加分差。

本题应该算是进阶版,思路一以贯之,先找个参照点比如max(w),然后sort排水量或等价的sum(ws),然后执行动作(浇水),然后在控制条件(max(w)==0)未满足时继续下一轮。

终极版还可以不均匀浇水(类似扇形喷嘴或者出水口离进水口距离不同而出水量不同)等。


http://www.kler.cn/a/290013.html

相关文章:

  • Vue常用加密方式
  • Linux——基础指令2 + 权限
  • 【论文阅读】利用SEM二维图像表征黏土矿物三维结构
  • Java反序列化之CommonsCollections2链的学习
  • 2.操作系统常见面试问题2
  • 组件间通信(组件间传递数据)
  • UE5.3 新学到的一些性能测试合计(曼巴学习笔记)
  • Unet改进10:在不同位置添加CPCA||通道先验卷积注意力机制
  • ARM内存屏障/编译屏障API(__DMB、__DSB、__ISB)用法及举例
  • 基于Spring的Uniapp自动更新实现方法
  • 一篇常见第三方库之以及详细使用示例教程
  • C++第四十五弹---深入理解包装器:提升代码复用性与安全性的利器
  • 浙大数据结构:01-复杂度3 二分查找
  • 一文读懂期权交易规则和操作方法分享
  • gitk无法打开
  • Python将两个Excel文件按相同字段合并到一起
  • gcc编译与Linux下的库
  • k8s dial tcp 10.97.0.1:443: i/o timeout
  • 帮招一名3C大佬机器视觉工程师,工作地:苏州,月薪25K-30K,30岁以下,Halcon独立开发,单休,有管理经验更佳有绩效奖
  • 飞利浦开放式耳机怎么样?飞利浦、西圣、漫步者爆火机型大对决!
  • SprinBoot+Vue宠物领养救助微信小程序的设计与实现
  • 解决firewalld启动状态下docker无法启动
  • AI时代的信仰是什么
  • macbook怎么换自定义壁纸?Mac怎么设置壁纸 macOS中如何轻松删除不需要的壁纸?
  • 86、pod部署策略
  • 动态爱心绘制:基于 turtle 库的实现