-
Notifications
You must be signed in to change notification settings - Fork 89
/
Copy pathKth Prime Number.py
109 lines (81 loc) · 2.36 KB
/
Kth Prime Number.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
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
"""
Design an algorithm to find the kth number such that the only prime factors are 3, 5, and 7.
The eligible numbers are like 3, 5, 7, 9, 15 ...
Example
If k=4, return 9.
Challenge
O(n log n) or O(n) time
"""
__author__ = 'Danyang'
class QueueNode(object):
def __init__(self, val):
self.val = val
self.q = [val] # queue, self.q = None
def __cmp__(self, other):
return self.val-other.val
def __repr__(self):
return repr(self.val)
def next(self):
self.q.pop(0)
self.val = self.q[0]
class Solution:
def kthPrimeNumber(self, k):
"""
heap and queue
:param k:
:return:
"""
import heapq
h1 = QueueNode(3)
h2 = QueueNode(5)
h3 = QueueNode(7)
heap = [h1, h2, h3]
heapq.heapify(heap)
for cnt in xrange(k-1):
h = heapq.heappop(heap)
if h == h1:
h1.q.append(h1.val*3)
h2.q.append(h1.val*5)
h3.q.append(h1.val*7)
elif h == h2:
h2.q.append(h2.val*5)
h3.q.append(h2.val*7)
else:
h3.q.append(h3.val*7)
h.next()
heapq.heappush(heap, h)
return heapq.heappop(heap).val
def kthPrimeNumber_error(self, k):
"""
heap and queue
Erroneous on re-appending the next items on the same queue
Example of errors: 45 is repeated, 45 = 3*3*5 and 45 = 3*5*3
:param k:
:return:
"""
import heapq
h1 = QueueNode(3)
h2 = QueueNode(5)
h3 = QueueNode(7)
heap = [h1, h2, h3]
heapq.heapify(heap)
for cnt in xrange(k-1):
h = heapq.heappop(heap)
if h == h1:
for i in [3, 5, 7]:
h1.q.append(i*h1.val)
h1.next()
heapq.heappush(heap, h1)
elif h == h2:
for i in [5, 7]:
h2.q.append(i*h2.val)
h2.next()
heapq.heappush(heap, h2)
else:
for i in [7]:
h3.q.append(i*h3.val)
h3.next()
heapq.heappush(heap, h3)
return heapq.heappop(heap).val
if __name__ == "__main__":
assert Solution().kthPrimeNumber(321) == 14586075