-
Notifications
You must be signed in to change notification settings - Fork 891
/
problem_283.py
38 lines (25 loc) · 943 Bytes
/
problem_283.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
from heapq import heappop, heappush
start_factor_counts = {2: 2, 3: 1, 5: 1}
def get_val_from_count(factor_counts):
total = 1
for key in factor_counts:
total *= key * factor_counts[key]
return total
def populate_heap(n, heap, regular_nums):
if len(regular_nums) >= n:
return
lowest_val, lowest_factors = heappop(heap)
regular_nums.add(lowest_val)
for key in lowest_factors:
lf_copy = lowest_factors.copy()
lf_copy[key] += 1
heappush(heap, (lowest_val * key, lf_copy))
populate_heap(n, heap, regular_nums)
def get_n_regular(n, factor_counts=dict()):
factor_counts = start_factor_counts
heap, regular_nums = list(), set()
heappush(heap, (get_val_from_count(factor_counts), factor_counts))
populate_heap(n, heap, regular_nums)
return sorted(regular_nums)
# Tests
assert get_n_regular(10) == [60, 120, 180, 240, 300, 360, 480, 540, 600, 720]