classSolution { public: intthreeSumClosest(vector<int>& nums, int target){ int n = nums.size(), res = 10000000; sort(nums.begin(), nums.end()); for (int i = 0; i < n - 2; ++i) { int l = i + 1, r = n - 1; while (l < r) { int sum = nums[i] + nums[l] + nums[r]; if (sum == target) return sum; if (abs(sum-target) < abs(res-target)) res = sum; if (sum > target) r--; else l++; } } return res; } };
python
classSolution: defthreeSumClosest(self, nums: List[int], target: int) -> int: n, res = len(nums), 10000000 nums.sort() for i inrange(n-2): l, r = i+1, n-1 while l < r: s = nums[i] + nums[l] + nums[r] if s == target: return s ifabs(s-target) < abs(res-target): res = s if s > target: r -= 1 else: l += 1 return res