全部开花的最早一天

217 阅读2分钟

5979. 全部开花的最早一天

题目

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

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

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

示例1

image.png

输入:plantTime = [1,4,3], growTime = [2,3,1]
输出:9
解释:灰色的花盆表示播种的日子,彩色的花盆表示生长的日子,花朵表示开花的日子。
一种最优方案是:
第 0 天,播种第 0 枚种子,种子生长 2 整天。并在第 3 天开花。
第 1234 天,播种第 1 枚种子。种子生长 3 整天,并在第 8 天开花。
第 567 天,播种第 2 枚种子。种子生长 1 整天,并在第 9 天开花。
因此,在第 9 天,所有种子都开花。 

题解

贪心

具体思路一句话:开花期越长,越先种植;

  • 种植的时候不影响鲜花生长,所以要将生长期比较长的日子先种下,最大可能的在生长期内种植更多的种子;直到种子种植完毕,找到种下种子的天数+生长期,找到最大天数即可得到答案
  • 理论证明,不太会

代码

var earliestFullBloom = function(plantTime, growTime) {
    const len = plantTime.length;
    let list = []
    let resutl = 0
    for(let i = 0 ; i < len ; i++){
        const x = plantTime[i]
        const y = growTime[i]
       list.push([y,x])
        
    }
    list.sort((a,b)=>b[0]- a[0]);
   
    // 开花期越长,越先种植;
    let day = list[0][1];
    // 花期
    let current = [day + list[0][0]]
    for(let i = 1 ; i < len ; i++){
        // 种植时间
        day+= list[i][1]; 
        current.push( day+list[i][0])
    }
    const max = Math.max(...current)
    return max

};