-
Notifications
You must be signed in to change notification settings - Fork 1.6k
/
Copy pathcount-the-number-of-k-big-indices.py
54 lines (47 loc) · 1.34 KB
/
count-the-number-of-k-big-indices.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
# Time: O(nlogk)
# Space: O(n)
import heapq
# heap
class Solution(object):
def kBigIndices(self, nums, k):
"""
:type nums: List[int]
:type k: int
:rtype: int
"""
right = [False]*len(nums)
max_heap1 = []
for i in reversed(xrange(len(nums))):
if len(max_heap1) == k and nums[i] > -max_heap1[0]:
right[i] = True
heapq.heappush(max_heap1, -nums[i])
if len(max_heap1) == k+1:
heapq.heappop(max_heap1)
result = 0
max_heap2 = []
for i in xrange(len(nums)):
if len(max_heap2) == k and nums[i] > -max_heap2[0] and right[i]:
result += 1
heapq.heappush(max_heap2, -nums[i])
if len(max_heap2) == k+1:
heapq.heappop(max_heap2)
return result
# Time: O(nlogn)
# Space: O(n)
from sortedcontainers import SortedList
# sorted list
class Solution2(object):
def kBigIndices(self, nums, k):
"""
:type nums: List[int]
:type k: int
:rtype: int
"""
sl1, sl2 = SortedList(), SortedList(nums)
result = 0
for x in nums:
sl2.remove(x)
if sl1.bisect_left(x) >= k and sl2.bisect_left(x) >= k:
result += 1
sl1.add(x)
return result