2023-09-30 LeetCode每日一题(全部开花的最早一天)

2023-03-29每日一题

一、题目编号

2136. 全部开花的最早一天

二、题目链接

点击跳转到题目位置

三、题目描述

你有 n 枚花的种子。每枚种子必须先种下,才能开始生长、开花。播种需要时间,种子的生长也是如此。给你两个下标从 0 开始的整数数组 plantTime 和 growTime ,每个数组的长度都是 n :

plantTime[i] 是 播种 第 i 枚种子所需的 完整天数 。每天,你只能为播种某一枚种子而劳作。无须 连续几天都在种同一枚种子,但是种子播种必须在你工作的天数达到 plantTime[i] 之后才算完成。
growTime[i] 是第 i 枚种子完全种下后生长所需的 完整天数 。在它生长的最后一天 之后 ,将会开花并且永远 绽放
从第 0 开始,你可以按 任意 顺序播种种子。

返回所有种子都开花的 最早 一天是第几天。

示例 1:
2023-09-30 LeetCode每日一题(全部开花的最早一天)_第1张图片

示例 2:
2023-09-30 LeetCode每日一题(全部开花的最早一天)_第2张图片
示例 3:
在这里插入图片描述
提示:

  • n == plantTime.length == growTime.length
  • 1 <= n <= 105
  • 1 <= plantTime[i], growTime[i] <= 104

四、解题代码

class Solution {
public:
    int earliestFullBloom(vector<int>& plantTime, vector<int>& growTime) {
        int n = plantTime.size();
        vector<int> id(n);  
        iota(id.begin(), id.end(), 0);
        sort(id.begin(), id.end(), [&](int i, int j) {
            return growTime[i] > growTime[j];
        });
        int prev = 0, ans = 0;
        for (int i: id) {
            ans = max(ans, prev + plantTime[i] + growTime[i]);
            prev += plantTime[i];
        }
        return ans;
    }
};

五、解题思路

(1) 自定义排序+贪心。

你可能感兴趣的:(LeetCode每日一题,leetcode,算法,数据结构)