-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy path3 Sum Closest.java
39 lines (38 loc) · 1.24 KB
/
3 Sum Closest.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
import java.util.ArrayList;
import java.util.Arrays;
public class Solution {
/**
* @param numbers: Give an array numbers of n integer
* @param target : An integer
* @return : return the sum of the three integers, the sum closest target.
*/
public int threeSumClosest(int[] numbers ,int target) {
// write your code here
if (numbers == null || numbers.length == 0) {
return 0;
}
int closet = Integer.MAX_VALUE / 2;
Arrays.sort(numbers);
for (int i = 0; i < numbers.length - 2; i++) {
if (i > 0 && numbers[i] == numbers[i - 1]) {
continue;
}
int left = i + 1;
int right = numbers.length - 1;
while (left < right) {
int sum = numbers[i] + numbers[left] + numbers[right];
if (sum == target) {
return target;
} else {
closet = Math.abs(sum - target) < Math.abs(closet - target) ? sum : closet;
if (sum < target) {
left++;
} else {
right--;
}
}
}
}
return closet;
}
}