题目内容
开放日活动的游戏规则如下:有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
该博客介绍了华为开放日活动的一个游戏规则,涉及到小球分配和容量限制问题。当所有小桶小球总数超过指定限制SUM时,需要设定一个最大容量并取出超限的小球。文章提供了输入输出描述、解题思路,包括利用二分查找法找到最佳容量限制,并给出了参考代码实现。
订阅专栏 解锁全文
7378

被折叠的 条评论
为什么被折叠?



