华为OD机试 - 开放日活动(Python)

华为开放日活动中有一个基于Python的机试题,涉及小球取球游戏。游戏规则要求若所有小桶小球总数超过限制,则需调整每个桶的容量并取出超出部分。解题思路采用贪心算法,通过Python实现判断和取出小球的操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

开放日活动

题目

某部门开展 Family Day 开放日活动,其中有个从桶里取球的游戏,
游戏规则如下:有 N 个容量一样的小桶等距排开,
且每个小桶都默认装了数量不等的小球,
每个小桶装的小球数量记录在数组bucketBallNums中,
游戏开始时,要求所有桶的小球总数不能超过SUM
如果小球总数超过SUM,则需对所有的小桶统一设置一个容量最大值maxCapacity
并需将超过容量最大值的小球拿出来,直至小桶里的小球数量小于maxCapacity;
请您根据输入的数据,计算从每个小桶里拿出的小球数量。
限制规则一:
所有所有小桶的小球总和小于SUM,则无需设置容量值,
并且无需从小桶中拿球出来,返回结果[];
限制规则二:
如果所有小桶的小球总和大于SUM,则需设置容量最大值maxCapacity
并且需从小桶中拿球出来,返回从每个小桶拿出的小球数量组成的数组;

输入

第一行输入2个正整数,数字之间使用空格隔开,其中第一个数字表示SUM,第二个数字表示bucketBallNums数组长度;
第二行输入N个正整数,数字之间使用空格隔开,表示bucketBallNums的每一项;

输出

示例一

输入

14 7
2 3 2 5 5 1 4

输出

[0,1,0,3,3,0,2]

说明

小球总数为22SUM=14,超出范围了,需从小桶取球,
maxCapacity=1,取出球后,桶里剩余小球总和为7,远小于14
maxCapacity=2,取出球后,桶里剩余小球总和为13
maxCapacity=3,取出球后,桶里剩余小球总和为16,大于14
因此maxCapacity为2 ,每个小桶小球数量大于 2 的都需要拿出来;

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-UliUHrBl-1676107611618)(.\images\Snipaste_2023-02-06_13-36-44.png)]

示例二

输入

3 3
1 2 3

输出

[0,1,2]

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

梦想橡皮擦

如有帮助,来瓶可乐

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值