LeetCode 每日一题笔记 日期:2026.05.12 题目:1665. 完成所有任务的最少初始能量

LeetCode 每日一题笔记

0. 前言

  • 日期:2026.05.12
  • 题目:1665. 完成所有任务的最少初始能量
  • 难度:中等
  • 标签:数组、贪心、排序

1. 题目理解

问题描述

给定二维数组 tasks,其中 tasks[i] = [实际消耗, 最低要求]

执行第 i 个任务必须满足:当前能量 ≥ 最低要求

执行后能量会 减去实际消耗

求完成所有任务需要的 最小初始能量

示例

输入:tasks = \[1,2,2,4,3,6,4,8]

输出:8

2. 解题思路

核心观察

  • 贪心策略:按(最低要求 - 实际消耗)降序排序
  • 先做"差值大"的任务,最后做"差值小"的任务,能让初始能量最小

算法步骤

  1. 排序:按 (b - a) 从大到小排序任务
  2. 先计算所有任务的总实际消耗(理论最低下限)
  3. 模拟执行任务,若当前能量不够最低要求,补充差值
  4. 最终得到最小初始能量

3. 代码实现

java 复制代码
package lc1665;

import java.util.Arrays;

class Solution {
    public int minimumEffort(int[][] tasks) {
        Arrays.sort(tasks, (row1, row2) -> {
            return (row2[1] - row2[0]) - (row1[1] - row1[0]);
        });
        int res = 0;
        for (int i = 0; i < tasks.length; i++) {
            res += tasks[i][0];
        }
        int temp = res;
        for (int i = 0; i < tasks.length; i++) {
            if (temp >= tasks[i][1]) {
                temp -= tasks[i][0];
            } else {
                res += tasks[i][1] - temp;
                temp = tasks[i][1] - tasks[i][0];
            }
        }
        return res;
    }
}

4. 代码优化说明

  • 贪心排序一次完成,无额外数据结构
  • 仅两次遍历,无嵌套循环
  • 空间 O(1) 额外空间,时间最优

5. 复杂度分析

  • 时间复杂度 :O(n log n)
    排序主导复杂度
  • 空间复杂度 :O(1)
    仅使用常数变量

6. 总结

  • 贪心核心:按 (b - a) 降序排列
  • 先算总消耗,再模拟补足不足
  • 是任务门槛类贪心的经典模板题
相关推荐
YHHLAI5 小时前
LeetCode 1.两数之和 | 从暴力枚举到线性优化
算法·leetcode·职场和发展
Urbano5 小时前
工装标准缝纫流程及自动化升级提质增产方案
大数据·人工智能·算法
三品吉他手会点灯6 小时前
STM32F103 学习笔记-24-I2C-读写EEPROM(第2节)-I2C协议层介绍
笔记·stm32·学习
KaMeidebaby6 小时前
卡梅德生物技术快报|biotin 生物素标记抗体全流程
前端·人工智能·算法·数据挖掘·数据分析
阳明山水6 小时前
自下而上 vs 自上而下 vs 最优组合预测策略解析
大数据·人工智能·深度学习·算法·机器学习
keykey6.6 小时前
从逻辑回归到 SVM:不仅仅是“分开“
算法·机器学习·支持向量机
QN1幻化引擎6 小时前
RingBuffer:用"循环缓冲区"干掉KV Cache的O(n)显存膨胀
算法·github
三品吉他手会点灯6 小时前
STM32F103 学习笔记-24-I2C-读写EEPROM(第3节)-STM32的I2C框图详解
笔记·stm32·学习
sheeta19986 小时前
LeetCode 每日一题笔记 日期:2026.06.14 题目:2130. 链表最大孪生和
笔记·leetcode·链表
Flittly6 小时前
【AgentScope Java新手村系列】(7)子Agent编排
java·spring boot·笔记·spring·ai