LeetCode 2919 使数组变美的最小增量运算数

news2025/4/19 0:32:53

动态规划解题:最小操作次数使数组变为美丽数组

问题描述

给定一个下标从0开始、长度为n的整数数组nums和一个整数k。你可以对数组中的任意一个元素进行加1操作,操作次数不限。如果数组中任意长度大于或等于3的子数组的最大值都大于或等于k,则称该数组为美丽数组。我们需要找到使数组变为美丽数组所需的最小操作次数。

问题分析

这个问题的核心是如何通过最少的操作次数,使得数组满足特定的条件。具体来说,我们需要确保数组中所有长度大于或等于3的子数组的最大值都大于或等于k。为了实现这一目标,我们可以使用动态规划的方法。

动态规划思路

动态规划是一种将复杂问题分解为子问题的算法思想。在这个问题中,我们可以定义一个数组dp[i],表示将数组nums的前i个元素变成美丽数组所需的最小操作次数。

状态定义
  • dp[i]:表示将数组nums的前i个元素变成美丽数组所需的最小操作次数。

状态转移

对于每个位置i,我们需要考虑以下三种情况:

  1. 只考虑当前元素:即nums[i]单独作为一个子数组的一部分。

  2. 当前元素与前一个元素一起考虑:即nums[i]nums[i-1]作为一个长度为2的子数组的一部分。

  3. 当前元素与前两个元素一起考虑:即nums[i]nums[i-1]nums[i-2]作为一个长度为3的子数组。

为了满足美丽数组的条件,我们需要确保:

  • 如果只考虑当前元素,那么nums[i]必须大于或等于k

  • 如果考虑当前元素与前一个元素,那么nums[i]nums[i-1]中至少有一个必须大于或等于k

  • 如果考虑当前元素与前两个元素,那么nums[i]nums[i-1]nums[i-2]中至少有一个必须大于或等于k

因此,dp[i]的值应该是:

  • 如果nums[i] >= k,则dp[i] = min(dp[i-1], dp[i-2], dp[i-3])

  • 如果nums[i] < k,则dp[i] = min(dp[i-1], dp[i-2], dp[i-3]) + (k - nums[i])

初始化
  • 如果数组长度小于3,直接返回0,因为不存在长度大于或等于3的子数组。

  • 初始化dp[0]dp[1]dp[2]

    • dp[0] = Math.max(0, k - nums[0]):只考虑第一个元素nums[0],如果它小于k,则需要k - nums[0]次操作。

    • dp[1] = Math.max(0, k - nums[1]):只考虑第二个元素nums[1],如果它小于k,则需要k - nums[1]次操作。

    • dp[2] = Math.max(0, k - nums[2]):只考虑第三个元素nums[2],如果它小于k,则需要k - nums[2]次操作。

返回结果

最终返回dp[n-1]dp[n-2]dp[n-3]中的最小值。这是因为最后一个元素可能与前两个元素一起考虑,因此需要选择最小的操作次数。

代码实现

以下是Java代码实现:

class Solution {
    public long minIncrementOperations(int[] nums, int k) {
        int n = nums.length;
        if (n < 3) {
            return 0; // 如果数组长度小于3,直接返回0
        }

        // dp[i]表示将数组nums的前i个元素变成美丽数组所需的最小操作次数
        long[] dp = new long[n];
        dp[0] = Math.max(0, k - nums[0]); // 初始化第一个位置
        dp[1] = Math.max(0, k - nums[1]); // 初始化第二个位置
        dp[2] = Math.max(0, k - nums[2]); // 初始化第三个位置

        // 动态规划计算
        for (int i = 3; i < n; i++) {
            // 当前位置需要的操作次数
            long currentCost = Math.max(0, k - nums[i]);
            // 选择最小的操作次数
            dp[i] = Math.min(dp[i - 1], Math.min(dp[i - 2], dp[i - 3])) + currentCost;
        }

        // 返回最后三个位置的最小值
        return Math.min(dp[n - 1], Math.min(dp[n - 2], dp[n - 3]));
    }
}

示例解析

假设nums = [2, 3, 5, 1, 4]k = 4

  1. 初始化

    • dp[0] = Math.max(0, 4 - 2) = 2

    • dp[1] = Math.max(0, 4 - 3) = 1

    • dp[2] = Math.max(0, 4 - 5) = 0

  2. 动态规划计算

    • i = 3

      • currentCost = Math.max(0, 4 - 1) = 3

      • dp[3] = min(dp[2], dp[1], dp[0]) + currentCost = min(0, 1, 2) + 3 = 3

    • i = 4

      • currentCost = Math.max(0, 4 - 4) = 0

      • dp[4] = min(dp[3], dp[2], dp[1]) + currentCost = min(3, 0, 1) + 0 = 0

  3. 返回结果

    • Math.min(dp[4], Math.min(dp[3], dp[2])) = Math.min(0, Math.min(3, 0)) = 0

因此,最终结果是0,表示不需要任何操作即可满足条件。

总结

通过动态规划,我们可以高效地解决这个问题。动态规划的关键在于:

  1. 定义合适的状态dp[i]

  2. 找到状态转移方程。

  3. 初始化边界条件。

  4. 返回最终结果。

希望这篇博客能帮助你更好地理解这个问题的解法!如果你有任何疑问或需要进一步的解释,欢迎留言讨论。

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

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

相关文章

[Web 安全] Web 信息收集 —— 信息收集流程

&#x1f31f; 想系统化学习 Web 渗透&#xff1f;看看这个&#xff1a;[Web 安全] Web 安全攻防 学习手册 提示&#xff1a;本章不涉及任何具体信息收集技术&#xff0c;仅仅是讲解收集这些信息我能干啥&#xff0c;以及如何才能比较全面的收集信息。 0x01&#xff1a;信息收…

内部聊天软件,BeeWorks-安全的企业内部通讯软件

企业在享受数据便利的同时&#xff0c;如何保障企业数据安全已经成为无法回避的重要课题。BeeWorks作为一款专为企业设计的内部通讯软件&#xff0c;通过全链路的安全能力升维&#xff0c;为企业提供了一个安全、高效、便捷的沟通协作平台&#xff0c;全面保障企业数据安全。 …

应用篇02-镜头标定(上)

本节主要介绍相机的标定方法&#xff0c;包括其内、外参数的求解&#xff0c;以及如何使用HALCON标定助手实现标定。 计算机视觉——相机标定(Camera Calibration)_摄像机标定-CSDN博客 1. 原理 本节介绍与相机标定相关的理论知识&#xff0c;不一定全&#xff0c;可以参考相…

【UE5 C++】“ProceduralMeshComponent”的使用记录

效果 如下所示&#xff0c;通过“ProceduralMeshComponent”创建了一个自定义形状的Mesh&#xff0c;并且该Mesh包含碰撞信息&#xff0c;然后2s后更新Mesh形状。 步骤 1. 在“xxx.Build.cs”中引入“ProceduralMeshComponent”模块 2. 新建一个Actor类&#xff0c;这里命名为…

(leetcode算法题)309. 买卖股票的最佳时机含冷冻期

按照题目要求&#xff0c;研究对象是最后一天结束后获得的最大利润 那么就可以把问题拆分成 第 1 天结束后获得的最大利润&#xff0c; 第 2 天结束后获得的最大利润&#xff0c; 第 i 天结束后获得的最大利润&#xff0c; 由于规则中强调不能同时参与多笔交易&#xff0c…

Chrome漏洞可窃取数据并获得未经授权的访问权限

在发现两个关键漏洞后,谷歌发布了Chrome浏览器的紧急安全更新。这些漏洞可能允许攻击者窃取敏感数据并未经授权访问用户系统。 这些缺陷被识别为CVE-2025-3619和CVE-2025-3620,在Windows和Mac的135.0.7049.95/.96之前影响Chrome版本,影响Linux的135.0.7049.95/.96。该更新将在…

.net core 项目快速接入Coze智能体-开箱即用-全局说明

目录 一、Coze智能体的核心价值 二、开箱即用-效果如下 三 流程与交互设计 为什么要分析意图&#xff0c;而不是全部交由AI处理。 四 接入前的准备工作 五&#xff1a;代码实现----字节Coze 签署 JWT和获取Token .net core 项目快速接入Coze智能体-开箱即用 .net core快…

风丘年度活动:2025年横滨汽车工程展览会

| 展会简介&#xff1a; 2025年横滨汽车工程展览会&#xff0c;是由日本汽车工程师学会&#xff08;JSAE&#xff09;精心主办的一场行业盛会。预计届时将汇聚超550家参展商&#xff0c;设置1300个展位&#xff0c;展览面积超过20000平方米。展会受众广泛&#xff0c;面向汽车…

Redis线上操作最佳实践有哪些?

大家好&#xff0c;我是锋哥。今天分享关于【Redis线上操作最佳实践有哪些?】面试题。希望对大家有帮助&#xff1b; Redis线上操作最佳实践有哪些? 1000道 互联网大厂Java工程师 精选面试题-Java资源分享网 在使用 Redis 时&#xff0c;尤其是在生产环境中&#xff0c;合理…

Redis——五种数据类型

目录 前言 1.String 1.1RAW编码 1.2EMBSTR编码 1.3 INT编码 2.List 3.Set 3.1 InSet编码转化成Dict编码 4.ZSet 4.1结合SkipList和HT实现 4.2使用ZipList实现 4.3编码转换 4.4 ZipList排序功能 5.Hash 5.1Hash底层存储结构 6.Redis数据结构和数据类型关系图 前言…

Godot学习-创建简单动画

文章目录 1、准备工作Godot资源 2、创建项目3、创建结点4、创建动画1、创建动画2、添加轨道3、创建关键帧3.1 第一个关键帧3.2 第二个关键帧 5、加载后自动播放6、动画循环7、轨道设置1、轨道更新模式2、轨迹插值3、其他属性的关键帧4、编辑关键帧5、使用 RESET 轨道6、洋葱皮 …

论文阅读VACE: All-in-One Video Creation and Editing

code&#xff1a;https://github.com/ali-vilab/VACE 核心 单个模型同时处理多种视频生成和视频编辑任务通过VCU&#xff08;视频条件单元&#xff09;进行实现 方法 视频任务 所有的视频相关任务可以分为4类 文本生视频 参考图片生视频 视频生视频 视频mask生视频 VCU …

JavaSE学习(前端初体验)

文章目录 前言一、准备环境二、创建站点&#xff08;创建一个文件夹&#xff09;三、将站点部署到编写器中四、VScode实用小设置五、案例展示 前言 首先了解前端三件套&#xff1a;HTML、CSS、JS HTML&#xff1a;超文本标记语言、框架层、描述数据的&#xff1b; CSS&#xf…

前端渲染pdf文件解决方案

一、前言 在当今数字化信息传播的时代&#xff0c;PDF文档作为一种常见的文件格式扮演着重要的角色。对于前端开发者而言&#xff0c;实现在网页上渲染和展示PDF文件是一项常见但也具有挑战性的任务。幸运的是&#xff0c;现在有一个强大的工具——react-pdf-viewer&#xff0c…

Kubernetes(K8S)内部功能总结

Kubernetes&#xff08;K8S&#xff09;是云技术的最核心的部分&#xff0c;也是构建是云原生的基石 K8S K8S&#xff0c;是Kubernetes的缩写&#xff0c;是Google开发的容器编排平台&#xff0c;现在由云原生计算基金会&#xff08;CNCF&#xff09;进行维护。 K8S&#xff…

【计算机网络】3数据链路层①

这篇笔记专门讲数据链路层的功能。 2.功能 数据链路层的主要任务是让帧在一段链路上或一个网络中传输。 2.1.封装成帧(组帧) 解决的问题:①帧定界②帧同步③透明传输 实现组帧的方法通常有以下种。 2.1.1.字符计数法 原理:在每个帧开头,用一个定长计数字段来记录该…

Nginx底层架构(非常清晰)

目录 前言&#xff1a; 场景带入&#xff1a; HTTP服务器是什么&#xff1f; 反向代理是什么&#xff1f; 模块化网关能力&#xff1a; 1.配置能力&#xff1a; 2.单线程&#xff1a; 3.多worker进程 4.共享内存&#xff1a; 5.proxy cache 6.master进程 最后&…

Docker 设置镜像源后仍无法拉取镜像问题排查

#记录工作 Windows系统 在使用 Docker 的过程中&#xff0c;许多用户会碰到设置了国内镜像源后&#xff0c;依旧无法拉取镜像的情况。接下来&#xff0c;记录了操作要点以及问题排查方法&#xff0c;帮助我们顺利解决这类问题。 Microsoft Windows [Version 10.0.27823.1000…

Edge 浏览器推出 Copilot Vision:免费实时解析屏幕内容;Aqua Voice:极速 AI 语音输入工具丨日报

开发者朋友们大家好 这里是 「RTE 开发者日报」 &#xff0c;每天和大家一起看新闻、聊八卦。我们的社区编辑团队会整理分享 RTE&#xff08;Real-Time Engagement&#xff09; 领域内「有话题的 技术 」、「有亮点的 产品 」、「有思考的 文章 」、「有态度的 观点 」、「有看…

async-profiler火焰图找出耗CPU方法

事情起于开发应用对依赖的三方包&#xff08;apache等等&#xff09;进行了升级后&#xff08;主要是升级spring&#xff09;&#xff0c;CPU的使用率较原来大幅提升&#xff0c;几个应用提升50%-100%。 查找半天&#xff0c;对比每次版本的cpu火焰图&#xff0c;看不出有什么…