Given an array S of n integers, are there elements a, b, c, and d in S such that a + b + c + d = target? Find all unique quadruplets in the array which gives the sum of target.
Note:
For example, given array S = {1 0 -1 0 -2 2}, and target = 0.
A solution set is:
(-1, 0, 0, 1)
(-2, -1, 1, 2)
(-2, 0, 0, 2)
給定一個包含n個整數的數組S,在數組S中是否存在元素a,b,c和d,使得 a + b + c + d = target.找出數組S中所有這樣的組合。
注意:
1.這四個元素必須是升序排列(ie, a ≤ b ≤ c ≤ d)
2.最終結果中不嫩包含重復的解。
For example, given array S = {1 0 -1 0 -2 2}, and target = 0.
A solution set is:
(-1, 0, 0, 1)
(-2, -1, 1, 2)
(-2, 0, 0, 2)
* 利用了題目《3Sum》的代碼 https://leetcode.com/problems/3sum/
* 首先升序排列數組,然後從第一個元素開始依次遍歷《3Sum》算法,目標值為(target-nums[i]),遍歷的數組為該元素後面的數組
* 這樣既滿足最終的arraylist中元素升序排列,也不會出現重復,因為每次以其為開始,進行遍歷的元素都是數組中的最小的元素
public class Solution
{
private static ArrayList> ret = new ArrayList>();
public ArrayList> fourSum(int[] nums, int target)
{
int newtarget=0;
ArrayList> finalres = new ArrayList>();
Arrays.sort(nums);
for (int i = 0; i < nums.length; i++)
{
ArrayList> temlist= new ArrayList>();
if (i > 0 && nums[i] == nums[i-1]) continue;//避免結果重復,其後面和它相等的直接被跳過。
newtarget=target-nums[i];
int inputnums[]=new int[nums.length -i-1];
for(int ii=0;ii> threeSum(int[] num,int newtarget,int firstnum)
{
if (num == null || num.length < 3) return ret;
Arrays.sort(num);
int len = num.length;
for (int i = 0; i < len-2; i++)
{
if (i > 0 && num[i] == num[i-1]) continue;//避免結果重復,其後面和它相等的直接被跳過。
find(num, i+1, len-1, num[i],newtarget, firstnum); //尋找兩個數與num[i]的和為0
}
return ret;
}
public static void find(int[] num, int begin, int end, int target,int newtarget,int firstnum)
{
int l = begin, r = end;
while (l < r)
{
if (num[l] + num[r] + target == newtarget)
{
ArrayList ans = new ArrayList();
ans.add(firstnum);//與原始的《3Sum》算法不同的地方為:記得把每次的啟示遍歷元素加入進去,就是4個數中的最小的那一個
ans.add(target);
ans.add(num[l]);
ans.add(num[r]);
ret.add(ans); //放入結果集中
while (l < r && num[l] == num[l+1]) l++;//避免結果重復,其後面和它相等的直接被跳過。
while (l < r && num[r] == num[r-1]) r--;////避免結果重復,其後面和它相等的直接被跳過。
l++;
r--;
}
else if (num[l] + num[r] + target < newtarget)
l++;
else
r--;
}
}
}