前言
两数之和
思路分析:
public List<List<Integer>> twoSum(int[] nums, int target) {
List<List<Integer>> result = new ArrayList<>();
Arrays.sort(nums);
int n = nums.length;
for (int i = 0; i < n; i++) {
if (i > 0 && nums[i] == nums[i - 1])continue;
int start = i, end = n - 1;
while (start < end){
long sum = (long) nums[start] + nums[end];
if (sum > target) end--;
else if (sum < target) start++;
else {
result.add(new ArrayList<>(Arrays.asList(nums[start],nums[end])));
while(start < end && nums[start] == nums[start + 1])start++;
while(start < end && nums[end] == nums[end - 1]) end--;
start++;end--;
}
}
}
return result;
}
三数之和

思路分析 :
public List<List<Integer>> threeSum(int[] nums) {
Arrays.sort(nums);
List<List<Integer>> result = new ArrayList<>();
for (int i = 0; i < nums.length - 2; i++) {
if (i > 0 && nums[i] == nums[i - 1]){
continue;
}
if (nums[i] > 0) return result;
int findNumber = -nums[i];
int start = i + 1 ,end = nums.length - 1;
while(start < end) {
if (nums[start] + nums[end] == findNumber) {
result.add(Arrays.asList(nums[i], nums[start], nums[end]));
while (start < end && nums[start] == nums[start + 1]) start++;
while (start < end && nums[end] == nums[end - 1]) end--;
start++;
end--;
}
else if (nums[start] + nums[end] > findNumber) end--;
else start++;
}
}
return result;
}
四数之和

思路分析:

public List<List<Integer>> fourSum(int[] nums, int target) {
List<List<Integer>> result = new ArrayList<>();
Arrays.sort(nums);
int n = nums.length;
for (int i = 0; i < n - 3; i++) {
if (i > 0 && nums[i] == nums[i - 1]) continue;
for (int j = i + 1; j < n - 2; j++) {
long findNumber = (long)target - nums[i] - nums[j];
if (j > i + 1 && nums[j] == nums[j - 1]) continue;
int start = j + 1,end = n - 1;
while(start < end){
if (nums[start] + nums[end] == findNumber){
result.add(new ArrayList<>(Arrays.asList(nums[i],nums[j],nums[start],nums[end])));
while (start < end && nums[start] == nums[start + 1]) start++;
while (start < end && nums[end] == nums[end - 1]) end--;
start++;end--;
} else if (nums[start] + nums[end] > findNumber) {
end--;
}else start++;
}
}
}
return result;
}
总结