-
Notifications
You must be signed in to change notification settings - Fork 1.6k
/
Copy pathfind-x-sum-of-all-k-long-subarrays-ii.py
47 lines (43 loc) · 1.28 KB
/
find-x-sum-of-all-k-long-subarrays-ii.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
# Time: O(nlogn)
# Space: O(n)
from sortedcontainers import SortedList
import collections
# freq table, sorted list, two pointers, sliding window
class Solution(object):
def findXSum(self, nums, k, x):
"""
:type nums: List[int]
:type k: int
:type x: int
:rtype: List[int]
"""
def update(v, d, curr):
if d == 1:
sl.add((-cnt[v], -v))
if sl.index((-cnt[v], -v)) < x:
curr += d*cnt[v]*v
if x < len(sl):
nc, nv = sl[x]
curr -= d*nc*nv
if d != 1:
sl.remove((-cnt[v], -v))
return curr
sl = SortedList()
cnt = collections.defaultdict(int)
result = []
curr = 0
for i, v in enumerate(nums):
if v in cnt:
curr = update(v, -1, curr)
cnt[v] += 1
curr = update(v, +1, curr)
if i < k-1:
continue
result.append(curr)
curr = update(nums[i-(k-1)], -1, curr)
cnt[nums[i-(k-1)]] -= 1
if cnt[nums[i-(k-1)]]:
curr = update(nums[i-(k-1)], +1, curr)
else:
del cnt[nums[i-(k-1)]]
return result