8.27 - hard - 110

630. Course Schedule III

现排序,再用heap,很多greedy的问题都可以这样来做。基本上就是排序,或者是heap,或者两者合用。

class Solution(object):
    def scheduleCourse(self, courses):
        """
        :type courses: List[List[int]]
        :rtype: int
        """
        A = courses
        pq = []
        start = 0
        for t, end in sorted(A, key = lambda (t, end): end):
            start += t
            heapq.heappush(pq, -t)
            while start > end:
                start += heapq.heappop(pq)
        return len(pq)
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 背景 一年多以前我在知乎上答了有关LeetCode的问题, 分享了一些自己做题目的经验。 张土汪:刷leetcod...
    土汪阅读 14,349评论 0 33
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,906评论 18 399
  • LeetCode 刷题随手记 - 第一部分 前 256 题(非会员),仅算法题,的吐槽 https://leetc...
    蕾娜漢默阅读 18,080评论 2 36
  • 面试有两道我现在还不明白的题 1.100枚硬币已知10枚为正面90枚反面。在黑箱子里如何分两堆,每堆正面向上个数相...
    爱吃鱼和莴苣的狗阅读 1,150评论 1 0
  • 因为住在岭南地区,其实去很多次香港,不过几乎都是当天来回……额,目标是购物,对象是和家人一起。 2017年8月30...
    筱迎儿阅读 1,774评论 0 0