leetcode-----16. 最接近的三数之和

代码

class Solution {
    public int threeSumClosest(int[] nums, int target) {
        int ans = nums[0] + nums[1] + nums[2];
        Arrays.sort(nums);
        int n = nums.length;

        for (int i = 0; i < n; ++i) {
            int l = i + 1, r = n - 1;
            while (l < r) {
                int sum = nums[i] + nums[l] + nums[r];
                if (Math.abs(sum - target) < Math.abs(ans - target)) {
                    ans = sum;
                }
                if (sum == target) {
                    return target;
                } else if (sum < target) l++;
                else r--;
            }
        }
        return ans;
    }
}
posted @ 2020-06-13 16:23  景云ⁿ  阅读(49)  评论(0编辑  收藏  举报