forked from kamyu104/LeetCode-Solutions
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfind-servers-that-handled-most-number-of-requests.py
69 lines (62 loc) · 2.52 KB
/
find-servers-that-handled-most-number-of-requests.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
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
# Time: O(nlogk)
# Space: O(k)
import itertools
import heapq
class Solution(object):
def busiestServers(self, k, arrival, load):
"""
:type k: int
:type arrival: List[int]
:type load: List[int]
:rtype: List[int]
"""
count = [0]*k
min_heap_of_endtimes = []
min_heap_of_nodes_after_curr = []
min_heap_of_nodes_before_curr = range(k)
for i, (t, l) in enumerate(itertools.izip(arrival, load)):
if i % k == 0:
min_heap_of_nodes_before_curr, min_heap_of_nodes_after_curr = [], min_heap_of_nodes_before_curr
while min_heap_of_endtimes and min_heap_of_endtimes[0][0] <= t:
_, free = heapq.heappop(min_heap_of_endtimes)
if free < i % k:
heapq.heappush(min_heap_of_nodes_before_curr, free)
else:
heapq.heappush(min_heap_of_nodes_after_curr, free)
min_heap_of_candidates = min_heap_of_nodes_after_curr if min_heap_of_nodes_after_curr else min_heap_of_nodes_before_curr
if not min_heap_of_candidates:
continue
node = heapq.heappop(min_heap_of_candidates)
count[node] += 1
heapq.heappush(min_heap_of_endtimes, (t+l, node))
max_count = max(count)
return [i for i in xrange(k) if count[i] == max_count]
# Time: O(nlogk)
# Space: O(k)
import sortedcontainers # required to do pip install
import itertools
import heapq
# reference: http://www.grantjenks.com/docs/sortedcontainers/sortedlist.html
class Solution2(object):
def busiestServers(self, k, arrival, load):
"""
:type k: int
:type arrival: List[int]
:type load: List[int]
:rtype: List[int]
"""
count = [0]*k
min_heap_of_endtimes = []
availables = sortedcontainers.SortedList(xrange(k)) # O(klogk)
for i, (t, l) in enumerate(itertools.izip(arrival, load)):
while min_heap_of_endtimes and min_heap_of_endtimes[0][0] <= t:
_, free = heapq.heappop(min_heap_of_endtimes) # O(logk)
availables.add(free) # O(logk)
if not availables:
continue
idx = availables.bisect_left(i % k) % len(availables) # O(logk)
node = availables.pop(idx) # O(logk)
count[node] += 1
heapq.heappush(min_heap_of_endtimes, (t+l, node)) # O(logk)
max_count = max(count)
return [i for i in xrange(k) if count[i] == max_count]