Leetcode 901 Solution
This article provides solution to leetcode question 901 (advantage-shuffle).
Access this page by simply typing in "lcs 901" in your browser address bar if you have bunnylol configured.
Leetcode Question Link
https://leetcode.com/problems/advantage-shuffle
Solution
class Solution:
def advantageCount(self, A: List[int], B: List[int]) -> List[int]:
A = sorted([(a, i) for i, a in enumerate(A)])
B = sorted([(b, i) for i, b in enumerate(B)])
i, j = 0, 0
ans = []
left_vals = []
left_indexes = []
while i < len(A) and j < len(B):
if A[i][0] > B[j][0]:
ans.append((B[j][1], A[i][0]))
j += 1
else:
left_vals.append(A[i][0])
i += 1
while j < len(B):
left_indexes.append(B[j][1])
j += 1
return [c for i, c in sorted(ans + list(zip(left_indexes, left_vals)))]