您的位置:首页 > 编程语言

【每天一道编程系列-2018.3.7】(Ans)

2018-03-07 23:44 447 查看
【题目描述】
  Given an array S of n integers, find three integers in S such that the sum is closest to a given number, target. Return the sum of the three integers. You may assume that each input would have exactly one solution. 
  For example, given array S = {-1 2 1 -4}, and target = 1. 
  The sum that is closest to the target is 2. (-1 + 2 + 1 = 2). 

【题目大意】给定包含n个整数数组S,找到S中的三个整数,从而使之和最接近给定的数。返回三个整数的总和。你可以假设每个输入将有一个确切的解决。 

【本题答案】
package blog;

import java.util.Arrays;

/**
* @author yesr
* @create 2018-03-07 下午11:45
* @desc
**/
public class Test0307 {
public int threeSumClosest(int[] nums, int target) {

// 记录最小的差值
long minDiff = Long.MAX_VALUE;
// 记录最小差值对应的三个整数和
long result = 0;
// 每次求得的差值
long diff;
// 每次求得的三个整数的和
long sum;

// 先对数组进行排序
Arrays.sort(nums);

// i表示假设取第i个数作为结果
for (int i = 0; i < nums.length - 2; i++) {
// 第二个数可能的起始位置
int j = i + 1;
// 第三个数可能是结束位置
int k = nums.length - 1;

while (j < k) {
// 求当前三个数的和
sum = nums[j] + nums[k] + nums[i];
// 当前和与目标和之间的差值
diff = Math.abs(target - sum);

// 差值为0就直接返回
if (diff == 0) {
return (int) sum;
}

// 如果当前的差值比之前记录的差值小
if (diff < minDiff) {
// 更新最小的差值
minDiff = diff;
// 更新最小差值对应的和
result = sum;

// 以上的设置在下一次元素处理时生效
}

// 和大于target
if (sum > target) {
k--;
}
// 和小于target
else {
j++;
}
}
}

return (int) result;
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  leetcode