forked from SamirPaulb/DSAlgo
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Count Reverse Pairs.py
54 lines (48 loc) Β· 1.66 KB
/
Count Reverse Pairs.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
# https://leetcode.com/problems/reverse-pairs/
# https://youtu.be/S6rsAlj_iB4
'''
use the merge sort concept of Inversion of Array
https://github.com/SamirPaulb/DSAlgo/blob/main/30-Days-SDE-Sheet-Practice/02.%20Day%202%20Arrays%20Part-II/Inversion%20of%20Array%20-using%20Merge%20Sort.py
'''
class Solution:
def __init__(self):
self.count = 0
def reversePairs(self, nums: List[int]) -> int:
self.mergeSort(nums)
return self.count
def mergeSort(self, nums):
if len(nums) > 1:
# calculate mid
mid = len(nums) // 2
# divide the input array in to right and left
left = nums[:mid]
right = nums[mid:]
self.mergeSort(left)
self.mergeSort(right)
# the tricky part - updating the count of number of possible pairs
j = 0
for i in range(len(left)):
while j < len(right) and left[i] > 2 * right[j]:
j += 1
self.count += j
# merge two sorted array
i = j = k = 0
while i < len(left) and j < len(right):
if left[i] <= right[j]:
nums[k] = left[i]
k += 1
i += 1
else:
nums[k] = right[j]
k += 1
j += 1
while i < len(left):
nums[k] = left[i]
k += 1
i += 1
while j < len(right):
nums[k] = right[j]
k += 1
j += 1
# Time: O(n log(n))
# Space: O(n)