【LeetCode】16. 4Sum

题目:Given an array S of n integers, are there elements abc, 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:

  • Elements in a quadruplet (a,b,c,d) must be in non-descending order. (ie, a ≤ b ≤ c ≤ d)
  • The solution set must not contain duplicate quadruplets.

给定一个数组,找出所有4个数的组合使得它们的和为target

思路:和3Sum,Two Sum都是类似的。主要是两个点:

1. 对数组排序,然后双指针分别从头尾遍历

2. 注意去重的问题

 1 class Solution {
 2 public:
 3     vector<vector<int>> fourSum(vector<int>& nums, int target) {
 4         int nsize = nums.size();
 5         sort(nums.begin(), nums.end());
 6         vector<vector<int>> result;
 7         for(int i = 0; i < nsize; i++){
 8             if(i != 0 && nums[i] == nums[i - 1])
 9                 continue;
10             for(int j = i + 1; j < nsize; j++){
11                 if(j != i + 1 && nums[j] == nums[j - 1])
12                     continue;
13                 int p = j + 1, q = nsize - 1;
14                 while(p < q){
15                     int sum = nums[i] + nums[j] + nums[p] + nums[q];
16                     if(sum < target){
17                         ++p;
18                         continue;
19                     }
20                     if(sum > target){
21                         --q;
22                         continue;
23                     }
24                    
25                         vector<int> tmp;
26                         tmp.push_back(nums[i]);
27                         tmp.push_back(nums[j]);
28                         tmp.push_back(nums[p]);
29                         tmp.push_back(nums[q]);
30                         result.push_back(tmp);
31                         
32                         while(++p < q && nums[p] == nums[p - 1]);
33                         while(p < --q && nums[q] == nums[q + 1]);
34                 }
35             }
36         }
37         return result;
38     }
39 };

 

posted @ 2016-03-28 22:29  huapyuan  阅读(152)  评论(0编辑  收藏  举报