[HOT 100] 2439. 最小化数组中的最大值
文章目录
- 1. 题目链接
- 2. 题目描述
- 3. 题目示例
- 4. 解题思路
- 5. 题解代码
- 6. 复杂度分析
1. 题目链接
2439. 最小化数组中的最大值 - 力扣(LeetCode)
2. 题目描述
给你一个下标从 0 开始的数组 nums ,它含有 n 个非负整数。
每一步操作中,你需要:
- 选择一个满足
1 <= i < n的整数i,且nums[i] > 0。 - 将
nums[i]减 1 。 - 将
nums[i - 1]加 1 。
你可以对数组执行 任意 次上述操作,请你返回可以得到的 nums 数组中 最大值 最小 为多少。
3. 题目示例
示例 1 :
输入:nums = [3,7,1,6]
输出:5
解释:
一串最优操作是:
1. 选择 i = 1 ,nums 变为 [4,6,1,6] 。
2. 选择 i = 3 ,nums 变为 [4,6,2,5] 。
3. 选择 i = 1 ,nums 变为 [5,5,2,5] 。
nums 中最大值为 5 。无法得到比 5 更小的最大值。
所以我们返回 5 。
示例 2 :
输入:nums = [10,1]
输出:10
解释:
最优解是不改动 nums ,10 是最大值,所以返回 10 。
4. 解题思路
- 二分查找确定候选值
- 最小可能值是0,最大可能值是数组的初始最大值。通过二分法逐步缩小范围,找到满足条件的最小最大值。
- 验证函数 (
**check**)- 从后向前遍历数组,计算每个元素在给定候选值
limit下是否需要转移多余的值到前一个元素。若所有元素最终能被调整到不超过limit,则候选值可行。
- 从后向前遍历数组,计算每个元素在给定候选值
5. 题解代码
class Solution {public int minimizeArrayValue(int[] nums) {int left = -1, right = 0;// 初始化右边界为数组最大值for (int x : nums) right = Math.max(right, x);// 二分查找:找到最小的可行最大值while (left + 1 < right) {int mid = (left + right) / 2;if (check(nums, mid)) {right = mid; // 可行,尝试更小的值} else {left = mid; // 不可行,增大下界}}return right; // 最终 right 是最小可行最大值}// 验证函数:判断是否所有元素可调整到不超过 limitprivate boolean check(int[] nums, int limit) {long extra = 0; // 记录需要向前转移的“多余量”for (int i = nums.length - 1; i > 0; i--) {// 当前元素值加上之前的转移量,若超过 limit,则计算新的转移量extra = Math.max(nums[i] + extra - limit, 0);}// 最终检查第一个元素是否能容纳所有转移量return nums[0] + extra <= limit;}
}
6. 复杂度分析
- 时间复杂度:O(n),其中n为nums的长度。
- 空间复杂度:O(1),仅用到若干变量。
相关文章:
[HOT 100] 2439. 最小化数组中的最大值
文章目录 1. 题目链接2. 题目描述3. 题目示例4. 解题思路5. 题解代码6. 复杂度分析 1. 题目链接 2439. 最小化数组中的最大值 - 力扣(LeetCode) 2. 题目描述 给你一个下标从 0 开始的数组 nums ,它含有 n 个非负整数。 每一步操作中&#…...
【JavaEE进阶】图书管理系统 - 贰
目录 🌲前言 🎄设计数据库 🍃引⼊MyBatis和MySQL驱动依赖 🌳Model创建 🎍约定前后端交互接口 🍀服务器代码 🚩控制层 🚩业务层 🚩数据层 🌴前端代码…...
Vue学习教程-14内置指令
文章目录 前言一、v-text指令二、v-html指令三、v-cloak指令四、v-once指令五、v-pre指令六、其他指令 前言 Vue.js 提供了许多内置指令(Directives),这些指令用于在模板中添加特殊功能。内置指令以 v- 前缀开始。 v-text : 更新元素的 tex…...
【蓝桥杯单片机】客观题
一、第十三届省赛(一) 二、第十三届省赛(二)...
C++ 设计模式-访问者模式
C++访问者模式 一、模式痛点:当if-else成为维护噩梦 开发动物园管理系统,最初的需求很简单: class Animal {}; class Cat : public Animal {}; class Dog : public Animal {};// 处理动物叫声 void makeSound(Animal* a) {if (auto c = dynamic_cast<Cat*>(a)) {st…...
靶场之路-Kioptix Level-1 mod_ssl 缓冲区溢出漏洞
声明 学习视频来自B站UP主 泷羽sec,如涉及侵泷羽sec权马上删除文章笔记的只是方便各位师傅学习知识,以下网站涉及学习内容,其他的都与本人无关,切莫逾越法律红线,否则后果自负 一、准备工作 首先使用 vmware 导入靶机文件, 然后网络模式改成 nat 模式即可 我们打…...
【Viewer.js】vue3封装图片查看器
效果图 需求 点击图片放大可关闭放大的 图片 下载 cnpm in viewerjs状态管理方法 stores/imgSeeStore.js import { defineStore } from pinia export const imgSeeStore defineStore(imgSeeStore, {state: () > ({showImgSee: false,ImgUrl: ,}),getters: {},actions: {…...
stm32mp采用spi接口扩展can
在 STM32MP 系列微处理器中,通过 SPI 转 CAN 功能扩展 CAN 接口需要结合硬件设计(如使用 SPI 接口的 CAN 控制器芯片)和 Linux 驱动配置。以下是详细的实现步骤和关键点: 硬件选型与连接 常用 SPI 转 CAN 芯片MCP2515:经典 SPI 转 CAN 控制器,支持 CAN 2.0B。MCP2517FD:…...
forge-1.21.x模组开发(二)给物品添加功能
功能效果 创建一个兑换券,当使用兑换券对着兑换机右键时,获得一条烤鱼 创建兑换券 创建ExchangeCouponsItem.java,继承Item,定义兑换券内容 public class ExchangeCouponsItem extends Item {public ExchangeCouponsItem(Prop…...
创建第一个 Maven 项目(一)
一、引言 在 Java 开发的广袤天地中,Maven 宛如一位全能的管家,发挥着举足轻重的作用。它是一个基于项目对象模型(POM)的项目管理和构建自动化工具,极大地简化了 Java 项目的开发流程。 Maven 的核心优势之一在于其强…...
网络运维学习笔记 022 HCIA-Datacom新增知识点03园区网典型组网架构及案例实战
园区网典型组网架构及案例实战 园区网:内部运行了园区网协议的一个主体网络 园区网络典型架构 园区网络常用协议与技术: 接入层: VLAN、生成树、链路聚合、AAA、dhcp-snooping等 汇聚层:DHCP、堆叠、链路聚合、生成树、OSPF、静…...
python-leetcode-二叉树的直径
543. 二叉树的直径 - 力扣(LeetCode) # Definition for a binary tree node. # class TreeNode: # def __init__(self, val0, leftNone, rightNone): # self.val val # self.left left # self.right right class Solutio…...
ubuntu中打包与压缩命令详解
Ubuntu 中打包与压缩命令详解 在 Ubuntu 系统中,打包和压缩文件是常见的操作。通过打包和压缩,可以将多个文件或目录合并为一个文件,并减小文件大小以节省存储空间或方便传输。本文将详细介绍 Ubuntu 中常用的打包与压缩命令及其用法。 目录…...
Linux MySQL 8.0.29 忽略表名大小写配置
Linux MySQL 8.0.29 忽略表名大小写配置 问题背景解决方案遇到的问题: 问题背景 突然发现有个大写的表报不存在。 在Windows上,MySQL是默认支持忽略大小写的。 这个时候你要查询一下是不是没有配置: SHOW VARIABLES LIKE lower_case_table…...
【c++】【线程池】线程池模式
【c】【线程池】线程池模式 1 L/F领导者与跟随者模式 概述:在此模式中,线程池中的线程分为:领导者(Leader),跟随者(Follower)和工作者(Processor) 领导者线…...
Next.js 学习-1
Next.js学习 引用:https://www.nextjs.cn/learn/basics/create-nextjs-app 先试试水吧,正好dify用的这个构建的前端项目。 使用 如果您尚未安装 Node.js,请 从此处安装。要求 Node.js 10.13 或更高版本。 好吧得用新的了,记得…...
bat命令在b站下载单个音视频
文章目录 单个音频第一行代码第二行代码下载后效果图 单个视频第一行代码第二行代码第三行代码第四行代码第五行代码下载后效果图 单个音视频第一行代码第二行代码第三行代码第四行代码第五行代码第六行代码下载后的效果图 单个音频 chcp 65001 you-get -o D:\Files\pydownloa…...
函数中的形参和实参(吐槽)
def greet_user(user_name):print(f"Hello,{user_name.title()}!")greet_user("zhangsan") 在以上函数中,user_name是形参, 在greet_user("zhangsan")中,值“zhangsan”是实参。这本身没什么大问题。 但是这…...
运维Ansible面试题及参考答案
目录 简述 Ansible 的工作原理,它是如何实现对远程主机管理的? Ansible 是基于什么语言开发的?这门语言的特性对 Ansible 的功能实现有哪些帮助? 解释 Agentless 在 Ansible 中的含义,与基于 Agent 的自动化工具相比,优势体现在哪? Ansible 中的 Inventory 文件是什…...
3、优先级翻转问题
FreeRTOS优先级翻转是当高优先级任务因等待低优先级任务占用的资源(如互斥锁)被阻塞,而中优先级任务趁机执行,导致高优先级任务无法及时运行的调度异常。 场景示例: 任务优先级:存在三个任务,优…...
从VGG16的参数量爆炸,聊聊为什么现在的CNN都不这么设计了(附PyTorch计算脚本)
从VGG16的参数量爆炸看CNN架构演进:设计哲学与技术突破 在计算机视觉领域,VGG16无疑是一座里程碑。2014年,当Simonyan和Zisserman提出这个看似简单的堆叠式卷积网络时,很少有人能预料到它会对深度学习架构设计产生如此深远的影响。…...
SQLite JDBC驱动:Java开发者应对嵌入式数据库挑战的终极方案
SQLite JDBC驱动:Java开发者应对嵌入式数据库挑战的终极方案 【免费下载链接】sqlite-jdbc SQLite JDBC Driver 项目地址: https://gitcode.com/gh_mirrors/sq/sqlite-jdbc 想象一下这样的场景:你正在开发一个需要轻量级数据存储的Java应用&#…...
从MobileNet V1到V3:谷歌轻量化CNN的演进史,如何影响了今天的端侧AI部署?
MobileNet进化史:轻量化CNN如何重塑边缘计算生态 当2016年AlphaGo击败李世石时,很少有人注意到支撑这场胜利的GPU集群功耗高达200千瓦——这相当于200台家用空调同时运转的能耗。而今天,我们口袋里的智能手机却能实时运行人脸识别、AR滤镜等A…...
018、多智能体协作(一):通信协议与协同机制
上周调试一个多机器人调度系统时,遇到了一个经典问题:两个智能体同时向对方发送任务请求,结果互相等待对方响应,直接死锁在通信层。查了一下午日志才发现,是我们的自定义消息协议没处理好并发请求的序列化。这个坑让我意识到,多智能体系统的核心往往不在算法本身,而在那…...
OpenAI 图像生成 API 的应用与使用
DALL-E 3 是 OpenAI 开发的一款图像生成模型,能够根据文本描述生成高质量的图像。通过 OpenAI 图像生成 API,开发者可以轻松利用 DALL-E 的图像生成功能,在各种应用场景中实现创意设计、内容生成等需求。 环境准备/前置条件 在开始之前&…...
为什么你的.NET AI服务无法突破200 QPS?揭秘JIT预编译+NativeAOT+TensorRT插件协同失效的3个隐性陷阱
第一章:为什么你的.NET AI服务无法突破200 QPS?揭秘JIT预编译NativeAOTTensorRT插件协同失效的3个隐性陷阱当.NET开发者将AI推理服务从Kestrel托管模型迁移至NativeAOT TensorRT加速路径时,常遭遇QPS卡死在180–200区间的现象——即使CPU利用…...
空洞骑士模组管理革命:Lumafly让300+模组一键搞定
空洞骑士模组管理革命:Lumafly让300模组一键搞定 【免费下载链接】Lumafly A cross platform mod manager for Hollow Knight written in Avalonia. 项目地址: https://gitcode.com/gh_mirrors/lu/Lumafly 还在为空洞骑士模组安装的繁琐流程而头疼吗&#x…...
告别IP黑名单:用JA3指纹在Suricata里精准揪出加密的恶意流量(附MSF检测规则)
加密流量狩猎实战:基于JA3指纹的Suricata高级威胁检测 当传统IP黑名单在加密流量面前失效时,安全工程师该如何应对?想象一个场景:某金融企业的内网监控系统发现异常外联流量,但目标IP每小时更换、通信内容全加密&#…...
保姆级教程:用R语言ggplot2为你的基因表达数据绘制带拟合线和统计指标的‘高级感’散点图
基因表达数据可视化:用ggplot2打造兼具科学性与美感的散点图 在生物信息学研究中,一张精心设计的散点图往往能比枯燥的数字表格更直观地揭示基因间的表达关系。当我们需要展示基因A与基因B的共表达模式时,基础的散点图虽然能完成任务…...
解密6自由度KUKA机械臂的智能搬运实战:前沿工业自动化技术深度剖析
解密6自由度KUKA机械臂的智能搬运实战:前沿工业自动化技术深度剖析 【免费下载链接】pick-place-robot Object picking and stowing with a 6-DOF KUKA Robot using ROS 项目地址: https://gitcode.com/gh_mirrors/pi/pick-place-robot 在工业4.0浪潮中&…...
