文章目录

  • 1. 题目
  • 2. 解题

1. 题目

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

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

从第 0 开始,你可以按 任意 顺序播种种子。

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

示例 1:

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

示例 2:

输入:plantTime = [1,2,3,2], growTime = [2,1,2,1]
输出:9
解释:灰色的花盆表示播种的日子,彩色的花盆表示生长的日子,花朵表示开花的日子。
一种最优方案是:
第 1 天,播种第 0 枚种子,种子生长 2 整天。并在第 4 天开花。
第 0、3 天,播种第 1 枚种子。种子生长 1 整天,并在第 5 天开花。
第 2、4、5 天,播种第 2 枚种子。种子生长 2 整天,并在第 8 天开花。
第 6、7 天,播种第 3 枚种子。种子生长 1 整天,并在第 9 天开花。
因此,在第 9 天,所有种子都开花。 示例 3:
输入:plantTime = [1], growTime = [1]
输出:2
解释:第 0 天,播种第 0 枚种子。种子需要生长 1 整天,然后在第 2 天开花。
因此,在第 2 天,所有种子都开花。提示:
n == plantTime.length == growTime.length
1 <= n <= 10^5
1 <= plantTime[i], growTime[i] <= 10^4

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/earliest-possible-day-of-full-bloom
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2. 解题

  • plan 时间是无法避免的都需要花费
  • 然后让生长耗时的先生长,避免最后长时间的等待
class Solution:def earliestFullBloom(self, plantTime: List[int], growTime: List[int]) -> int:pg = list(zip(plantTime, growTime))pg.sort(key=lambda x : x[1], reverse=True) # 生长时间大的优先ans = 0allptime = 0for p, g in pg:allptime += pans = max(ans, allptime+g)return ans

312 ms 31.8 MB Python3


我的CSDN博客地址 https://michael.blog.csdn.net/

长按或扫码关注我的公众号(Michael阿明),一起加油、一起学习进步!

LeetCode 2136. 全部开花的最早一天(贪心)相关推荐

  1. LeetCode 1101. 彼此熟识的最早时间(排序+并查集)

    文章目录 1. 题目 2. 解题 1. 题目 在一个社交圈子当中,有 N 个人.每个人都有一个从 0 到 N-1 唯一的 id 编号. 我们有一份日志列表 logs,其中每条记录都包含一个非负整数的时 ...

  2. LeetCode 6055. 转化时间需要的最少操作数(贪心)

    文章目录 1. 题目 2. 解题 1. 题目 给你两个字符串 current 和 correct ,表示两个 24 小时制时间 . 24 小时制时间 按 "HH:MM" 进行格式化 ...

  3. LeetCode 807. 保持城市天际线 / 630. 课程表 III(贪心+优先队列)/ 851. 喧闹和富有(拓扑排序)

    807. 保持城市天际线 2021.12.13 每日一题 题目描述 给你一座由 n x n 个街区组成的城市,每个街区都包含一座立方体建筑.给你一个下标从 0 开始的 n x n 整数矩阵 grid ...

  4. LeetCode Maximum XOR of Two Numbers in an Array(贪心、字典树)

    问题:给出一个非空的整数数组,找到最大的两个数的异或值.要求时间复杂度为O(n) 思路:根据二进制表示的前缀. 先求出最大数的位数,然后根据位数作位操作异或判断最大值.由于要求时间复杂度为O(n),在 ...

  5. leetcode 53. 最大子序和 动态规划解法、贪心法以及二分法

    题目 给定一个整数数组 nums ,找到一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和. 示例: 输入: [-2,1,-3,4,-1,2,1,-5,4] 输出: 6 解释: 连续子 ...

  6. LeetCode 2144. 打折购买糖果的最小开销(贪心)

    文章目录 1. 题目 2. 解题 1. 题目 一家商店正在打折销售糖果.每购买 两个 糖果,商店会 免费 送一个糖果. 免费送的糖果唯一的限制是:它的价格需要小于等于购买的两个糖果价格的 较小值 . ...

  7. LeetCode 2139. 得到目标值的最少行动次数(贪心)

    文章目录 1. 题目 2. 解题 1. 题目 你正在玩一个整数游戏.从整数 1 开始,期望得到整数 target . 在一次行动中,你可以做下述两种操作之一: 递增,将当前整数的值加 1(即, x = ...

  8. LeetCode 2033. 获取单值网格的最小操作数(贪心)

    文章目录 1. 题目 2. 解题 1. 题目 给你一个大小为 m x n 的二维整数网格 grid 和一个整数 x . 每一次操作,你可以对 grid 中的任一元素 加 x 或 减 x . 单值网格 ...

  9. LeetCode 1718. 构建字典序最大的可行序列(贪心+回溯)

    文章目录 1. 题目 2. 解题 1. 题目 给你一个整数 n ,请你找到满足下面条件的一个序列: 整数 1 在序列中只出现一次. 2 到 n 之间每个整数都恰好出现两次. 对于每个 2 到 n 之间 ...

最新文章

  1. 零基础学Java程序有什么好的建议
  2. 笑了,面试官问我知不知道异步编程的Future。
  3. pytorch MaxUnpool2d
  4. oracle 如何添加数据文件,Oracle教程 误添加数据文件删除方法
  5. 【NLP】 深入浅出解析BERT原理及其表征的内容
  6. web.xml中 Log4jConfigListener配置
  7. 浅析继承关系中的方法调用
  8. 华为Mate X 5G再次秒售罄;全新折叠屏手机渲染图曝光:确实不一般!
  9. 自学python到什么程度可以找工作-Python学到什么程度就可以找工作?
  10. 5 helloword 开发运行步骤
  11. vue2.0配置 https://github.com/wike933/vuebook
  12. 手机分辨率和网页中的px是一回事吗?
  13. 【MFC】Ribbon界面开发(三)
  14. 数组排序和集合排序的使用
  15. java中一行代码实现百分数计算
  16. mui 图片预览(3)
  17. 访问页面出错:The requested URL / was not found on this server. 网站打开出现404
  18. Ubuntu 常用软件推荐(QQ、微信、MATLAB等)及安装过程
  19. stm32f407的串口通信传输不了且串口调试软件无法显示的问题
  20. 半导体显示丨三星显示器拟投资逾21.5亿美元抢占OLED电视面板市场

热门文章

  1. php 模板 php + mysql + myodbc,连接MySQL数据库在ASP中,就用MyODBC
  2. 电子科学与技术相关索引汇总
  3. arch mysql日志位置_MySQL 日志文件与相关参数
  4. kotlin编译失败_Kotlin使用GraalVM开发原生命令行应用
  5. c语言编程题目(一)
  6. 一些自己编写的字符串操作函数
  7. jdk8 Function
  8. Go语言web框架 gin
  9. (四)Kinect人脸识别
  10. 外网访问FTP服务,解决只能以POST模式访问Filezilla的问题