-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path630.course-schedule-iii.py
54 lines (52 loc) · 1.54 KB
/
630.course-schedule-iii.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
#
# @lc app=leetcode id=630 lang=python3
#
# [630] Course Schedule III
#
# https://leetcode.com/problems/course-schedule-iii/description/
#
# algorithms
# Hard (31.04%)
# Total Accepted: 10.3K
# Total Submissions: 33.3K
# Testcase Example: '[[100,200],[200,1300],[1000,1250],[2000,3200]]'
#
# There are n different online courses numbered from 1 to n. Each course has
# some duration(course length) t and closed on dth day. A course should be
# taken continuously for t days and must be finished before or on the dth day.
# You will start at the 1st day.
#
# Given n online courses represented by pairs (t,d), your task is to find the
# maximal number of courses that can be taken.
#
# Example:
#
#
# Input: [[100, 200], [200, 1300], [1000, 1250], [2000, 3200]]
# Output: 3
# Explanation:
# There're totally 4 courses, but you can take 3 courses at most:
# First, take the 1st course, it costs 100 days so you will finish it on the
# 100th day, and ready to take the next course on the 101st day.
# Second, take the 3rd course, it costs 1000 days so you will finish it on the
# 1100th day, and ready to take the next course on the 1101st day.
# Third, take the 2nd course, it costs 200 days so you will finish it on the
# 1300th day.
# The 4th course cannot be taken now, since you will finish it on the 3300th
# day, which exceeds the closed date.
#
#
#
#
# Note:
#
#
# The integer 1 <= d, t, n <= 10,000.
# You can't take two courses simultaneously.
#
#
#
#
#
class Solution:
def scheduleCourse(self, courses: List[List[int]]) -> int: