Leetcode 658 Solution
This article provides solution to leetcode question 658 (find-k-closest-elements).
Access this page by simply typing in "lcs 658" in your browser address bar if you have bunnylol configured.
Leetcode Question Link
https://leetcode.com/problems/find-k-closest-elements
Solution
class Solution:
def findClosestElements(self, arr: List[int], k: int, x: int) -> List[int]:
l = 0
r = len(arr) - 1
while l < r:
m = (l + r) // 2
if arr[m] >= x:
r = m
else:
l = m + 1
r = l
l = l - 1
ans1 = []
ans2 = []
while (l > 0 or r < len(arr)) and len(ans1) + len(ans2) < k:
left_dist = x - arr[l] if l >= 0 else 100000
right_dist = arr[r] - x if r < len(arr) else 100000
if left_dist <= right_dist:
ans1.append(arr[l])
l -= 1
else:
ans2.append(arr[r])
r += 1
return list(reversed(ans1)) + ans2