-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdailycoding021.py
More file actions
37 lines (28 loc) · 823 Bytes
/
dailycoding021.py
File metadata and controls
37 lines (28 loc) · 823 Bytes
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
def sort_by_start(times):
return sorted(times, key=lambda time: time[0])
def min_rooms(times):
sorted_times = sort_by_start(times)
rooms = 0
queue = []
queue.append(sorted_times[0])
for t in range(1, len(sorted_times)):
while queue and queue[0][1] < sorted_times[t][0]:
queue.pop(0)
queue.append(sorted_times[t])
rooms = max(rooms, len(queue))
return rooms
def main():
import numpy as np
a = np.a
times = [
([(0, 30), (40, 60), (70, 80)], 1),
([(30, 75), (0, 50), (60, 150)], 2),
([(0, 30), (10, 50), (20, 100)], 3),
([(0, 100), (10, 90), (20, 80)], 3)
]
if all([min_rooms(t) == r for t, r in times]):
print("Passed")
else:
print("Failed")
if __name__ == '__main__':
main()