[LeetCode 1760]袋子里最少数目的球

news2025/2/4 22:38:23

题目描述

题目链接:[LeetCode 1760]袋子里最少数目的球

给你一个整数数组 nums ,其中 nums[i] 表示第 i 个袋子里球的数目。同时给你一个整数 maxOperations 。

你可以进行如下操作至多 maxOperations 次:

  • 选择任意一个袋子,并将袋子里的球分到 2 个新的袋子中,每个袋子里都有 正整数 个球。
  • 比方说,一个袋子里有 5 个球,你可以把它们分到两个新袋子里,分别有 1 个和 4 个球,或者分别有 2 个和 3 个球。
    你的开销是单个袋子里球数目的 最大值 ,你想要 最小化 开销。

请你返回进行上述操作后的最小开销。

示例1

输入:nums = [9], maxOperations = 2
输出:3
解释

  • 将装有 9 个球的袋子分成装有 6 个和 3 个球的袋子。[9] -> [6,3] 。
  • 将装有 6 个球的袋子分成装有 3 个和 3 个球的袋子。[6,3] -> [3,3,3] 。
    装有最多球的袋子里装有 3 个球,所以开销为 3 并返回 3 。

示例2

输入:nums = [2,4,8,2], maxOperations = 4
输出:2
解释

  • 将装有 8 个球的袋子分成装有 4 个和 4 个球的袋子。[2,4,8,2] -> [2,4,4,4,2] 。
  • 将装有 4 个球的袋子分成装有 2 个和 2 个球的袋子。[2,4,4,4,2] -> [2,2,2,4,4,2] 。
  • 将装有 4 个球的袋子分成装有 2 个和 2 个球的袋子。[2,2,2,4,4,2] -> [2,2,2,2,2,4,2] 。
  • 将装有 4 个球的袋子分成装有 2 个和 2 个球的袋子。[2,2,2,2,2,4,2] -> [2,2,2,2,2,2,2,2] 。
    装有最多球的袋子里装有 2 个球,所以开销为 2 并返回 2 。

示例3

输入:nums = [7,17], maxOperations = 2
输出:7

提示

1 <= nums.length <= 1 0 5 10^5 105
1 <= maxOperations, nums[i] <= 1 0 9 10^9 109

思路分析

数据范围是 1 0 5 10^5 105,因此控制算法的时间复杂度在O(nlogn)这个级别以下,第一时间想到的是贪心+优先队列,就每次处理最大值,发现这条路走不通,最后通过二分解决

要理解二分的核心思想:
1.具有某种性质
2.边界点

具体到这一道题,我们可以定义:
在边界点右边的所有点,它的操作次数都要小于或等于maxOperations,因为当每个袋子的开销变大,它的分割次数会变小
例如:如果开销是5,某个袋子是25,那么需要划分4次,才能让每个袋子都是5
如果开销增大,变成10,那么只需要划分2次,即[10, 10, 5]或者[8, 8, 9]
在这里插入图片描述

好,性质找出来了,然后第二步就是找边界点:
情况1:如果mid在区间内,如图所示,下一步,R自然要移动到R’的位置,即R = mid
在这里插入图片描述

情况2:如果mid不在区间内,如图所示,下一步,L移动到L’的位置,即L’=mid + 1
至于为什么L’不是变成mid,因为情况1中,边界点也是满足cnt <= maxOperations条件的,如果mid刚好等于边界点,那么R = mid - 1就会找不到边界点

而情况2中,mid不满足条件,显然它不可能是边界点,从而L’设为mid + 1
在这里插入图片描述

代码

class Solution {
public:
    int minimumSize(vector<int>& nums, int maxOperations) {
        int n = nums.size(), m = -1;
        //m寻找装有最大数量的球的袋子,作为右边界
        for(int i = 0; i < n; i++) m = max(m, nums[i]);
        int l = 1, r = m;
        while(l < r) {
        	//cnt记录代价为mid时,需要使用的步数
            int mid = l + r >> 1, cnt = 0;
            for(int i = 0; i < n; i++)
            	//步数为nums[i] / mid上取整 - 1
            	//例如袋子里有9个,代价为3, 只需要分9 / 3 - 1 = 2次就行
            	//袋子里有9个,代价为4, 也需要(9 / 4)上取整 - 1 = 2次
                cnt += (nums[i] + mid - 1) / mid - 1;
            //看之前的分析,就很清楚了
            if(cnt <= maxOperations) r = mid;
            else l = mid + 1; 
        }

        return l;
    }
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/103335.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

week8 正交化/human-level error/train,dev,test sets

文章目录前言一、8.1,8.2 正交化二、8.3,8.4评估指标1、 单一量化评估指标2、满足和优化指标三、8.5-8.7训练开发测试数据集1、训练开发测试数据集的分布。2、训练开发测试数据集的大小选择3、何时更改指标或者开发测试数据集四、 8.8-8.12 与人类水平相比较1、为什么选择与人类…

单商户商城系统功能拆解49—应用中心—在线客服

单商户商城系统&#xff0c;也称为B2C自营电商模式单店商城系统。可以快速帮助个人、机构和企业搭建自己的私域交易线上商城。 单商户商城系统完美契合私域流量变现闭环交易使用。通常拥有丰富的营销玩法&#xff0c;例如拼团&#xff0c;秒杀&#xff0c;砍价&#xff0c;包邮…

工业物联网解决方案:油井数据远程监控系统

石油行业是国民经济的重要能源支柱&#xff0c;是推动工业发展的原动力。随着物联网、云计算、5G无线通信等技术的发展&#xff0c;多种要素驱动下的生产系统逐步向着数字化转型&#xff0c;重要性越来越明显。油井数字化就是其中的重要一环。 油田开采区域广阔&#xff0c;分…

【苹果推iMessage送】摆设overrideUserInterfaceStyle属性以使该视图及其子视图具备特定的UIUserInterfaceStyle

推荐内容IMESSGAE相关 作者推荐内容iMessage苹果推软件 *** 点击即可查看作者要求内容信息作者推荐内容1.家庭推内容 *** 点击即可查看作者要求内容信息作者推荐内容2.相册推 *** 点击即可查看作者要求内容信息作者推荐内容3.日历推 *** 点击即可查看作者要求内容信息作者推荐…

攻防世界-宜兴网信办-fileinclude

题目 访问题目场景 查看网页源代码&#xff0c;发现其中存在php代码 <?php if( !ini_get(display_errors) ) { //ini_get是获取php.ini里的环境变量的值。环境变量未设置错误回显ini_set(display_errors, On);} error_reporting(E_ALL);//报告所有类型的错误 $lan $_COOK…

微信小程序遍历Echarts图表,实现遍历多个柱状图

1.wxml文件 <view stylewidth:100%;height:200rpx><ec-canvas id"mychart-dom-bar" canvas-id"mychart-bar" ec"{{ ec }}"></ec-canvas> </view>2.js文件 import * as echarts from ../../common/ec-canvas/echarts; …

rocketmq源码-consumer已消费offset更新逻辑

前言 这篇博客&#xff0c;主要记录consumer已经消费的offset是如何更新的 对于集群模式&#xff0c;offset是维护在broker中的&#xff1b;而广播模式&#xff0c;offset是存储在本地文件中&#xff08;暂时没有验证具体存储的位置&#xff0c;是根据源码推测的&#xff09;…

socket,http和websocket的区别

HTTP协议是非持久化的&#xff0c;单向的网络协议&#xff0c;在建立连接后只允许浏览器向服务器发出请求后&#xff0c;服务器才能返回相应的数据。当需要即时通讯时&#xff0c;通过轮询在特定的时间间隔&#xff08;如1秒&#xff09;&#xff0c;由浏览器向服务器发送Reque…

Delft3D水动力-富营养化模型

湖泊富营养化等水质问题严重威胁我国经济社会的发展&#xff0c;也是水环境和水生态领域科研热点之一。水环境模型是制定湖泊富营养化控制对策&#xff0c;预测湖泊水环境发展轨迹的重要工具&#xff0c;在环境影响评价、排污口论证等方面也有着广泛的应用。荷兰Delft研究所开发…

Oracle数据库:数据的仓库,永久就存储,Oracle安装教程,修改Oracle scott,sys,system用户的密码,查看表格

Oracle数据库&#xff1a;数据的仓库&#xff0c;永久就存储&#xff0c;Oracle安装教程&#xff0c;修改Oracle scott&#xff0c;sys&#xff0c;system用户的密码&#xff0c;查看表格 2022找工作是学历、能力和运气的超强结合体&#xff0c;遇到寒冬&#xff0c;大厂不招人…

Diffusion理论知识学习-预备

马尔科夫链 总体思想: 过去的所有信息都被保存在了现在的状态中&#xff0c;只使用现在状态就能预测到之后的状态&#xff0c;换句话说就是某个时刻的状态转移概率只依赖于它的前一个状态。 公式化表达:P(xt1∣xt,xt−1,...,x1,x0)P(xt1∣xt)P(x_{t1}|x_t,x_{t-1},...,x_1,x_0…

打造钢材行业智能制造新业态,B2B电商平台系统赋能企业交易全链路数字化

钢铁行业是制造业的“脊梁”&#xff0c;是工业的“粮食”&#xff0c;在我国由制造大国向制造强国挺进的过程中&#xff0c;钢铁行业由全球“老大”变“强大”至关重要&#xff0c;而数字化转型将发挥不可替代的作用&#xff0c;实施绿色制造、智能制造和精益制造&#xff0c;…

阿里中间件的源与流

目录前言从中间件->中台->阿里云从五彩石项目说起从HSF到EDAS从TDDL到PolarDB-XTDDL阶段DRDS阶段PolarDB-X 1.0阶段PolarDB-X 2.0阶段从Notify到RocketMQ阿里中间件一览参考链接前言 阿里中间件如雷贯耳&#xff0c;听上去高深莫测&#xff0c;那到底是哪几样神兵利器呢…

【MySQL】1.MySQL基础

文章目录1.0 数据库基本概念1.1 主流数据库介绍2.0 MySQL数据库架构2.1 MySQL软件分层2.1 MySQL存储引擎2.2 SQL语句分类1.0 数据库基本概念 想要理解数据库的概念&#xff0c;首先要了解数据库为何存在&#xff0c;它存在的价值是什么&#xff1f; 在之前的学习中&#xff0c…

用Python绑定调用C/C++/Rust库

用Python绑定调用C/C/Rust库 在《让你的Python程序像C语言一样快》我们学习了如何利用Python API来用C语言编写Python模块&#xff0c;通过将核心功能或性能敏感运算用C语言实现&#xff0c;Python程序可以运行地像C语言一样快。然而&#xff0c;很多时候我们需要的功能已经有…

Mycat(11):分片详解之字符串ID处理

1 找到conf/schema.xml并备份 2 字符串ID处理的分区算法 conf/rule.xml <tableRule name"jch"><rule><columns>id</columns><algorithm>jump-consistent-hash</algorithm></rule></tableRule><function name&qu…

css之grid布局个人学习笔记

前置 只是个人学习,内容只会记录自己想知道,有问题的知识点具体可以看看bilibili的耕耕技术宅-grid布局地址视频对应的耕耕技术宅-grid布局ppt地址学有余力的可以通关下这个小游戏通过给萝卜浇水&#xff0c;学习 CSS 网格布局CSS Grid 网格布局教程- 阮一峰 明确基本概念 下…

品牌创建百科怎么写?品牌百度百科怎么创建?

每年都会有很多新成立的品牌&#xff0c;但是能够被大众所熟知的却是寥寥无几&#xff0c;众多品牌都被淹没在了大千世界里。 一个品牌的创建&#xff0c;难的就在于宣传&#xff0c;宣传力度不到位&#xff0c;就没有用户会愿意为这个品牌买单。 那么怎么快速提升品牌的知名度…

肝完这在“牛客网”难倒万人的Java面试题后,已收获9个大厂offer

上周在牛客网看到了这几百道面试题之后&#xff0c;看到评论区全是太难了&#xff01;太难了&#xff0c;就深深被其吸引&#xff0c;索性直接花了一周的时间才把它们全部解析出来做成了这份文档&#xff0c;发给了最近面试的粉丝&#xff0c;他刷爆之后居然能拿到了好几个大厂…

IDEA集成docker-JDK11版本

IDEA集成docker 1. docker 服务器开启远程访问 登录 docker 所在的远程服务器&#xff0c;使用命令 vim /usr/lib/systemd/system/docker.service 修改配置文件&#xff0c;需注意&#xff0c;修改时确认自己的账户拥有相应权限 主要操作是找到 ExecStart/usr/bin/dockerd -H…