-
Notifications
You must be signed in to change notification settings - Fork 892
/
Copy pathproblem_360.py
32 lines (25 loc) · 843 Bytes
/
problem_360.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
from heapq import heappush, heappop
def interleave_playlist(ranked_listings):
scores = dict()
for listing in ranked_listings:
num_songs = len(listing)
total_points = ((num_songs + 1) * num_songs) // 2
for rank, song in enumerate(listing):
if song not in scores:
scores[song] = 0
scores[song] += total_points / (rank + 1)
sorted_scored_tuples = list()
for song, score in scores.items():
heappush(sorted_scored_tuples, (score, song))
interleaved = list()
while sorted_scored_tuples:
_, song = heappop(sorted_scored_tuples)
interleaved.append(song)
return interleaved[::-1]
# Tests
ranked_listings = [
[1, 7, 3],
[2, 1, 6, 7, 9],
[3, 9, 5]
]
assert interleave_playlist(ranked_listings) == [2, 1, 3, 7, 9, 6, 5]