您的位置:首页 > 其它

[LeetCode] 3Sum Closest

2015-06-10 22:57 501 查看
This problem is very similar to 3Sum. You only need to maintain a variable for the sum that is closet to target. Also, some corner cases need to be handled; for example, nums does not have more than 2 elements.

The code is as follows, which is quite self-explanatory.

int threeSumClosest(vector<int>& nums, int target) {
sort(nums.begin(), nums.end());
while (nums.size() <= 2)
return accumulate(nums.begin(), nums.end(), 0);
int ans = nums[0] + nums[1] + nums[2];
for (int i = 0; i < nums.size() - 2; i++) {
int left = i + 1, right = nums.size() - 1;
while (left < right) {
int temp = nums[i] + nums[left] + nums[right];
if (abs(temp - target) < abs(ans - target))
ans = temp;
if (temp == target) return ans;
if (temp > target) right--;
else left++;
}
}
return ans;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: