1. 程式人生 > 實用技巧 >18. 四數之和

18. 四數之和

18. 四數之和

給定一個包含 n 個整數的陣列 nums 和一個目標值 target,判斷 nums 中是否存在四個元素 a,b,c 和 d ,使得 a + b + c + d 的值與 target 相等?找出所有滿足條件且不重複的四元組。 注意: 答案中不可以包含重複的四元組。 示例: 給定陣列 nums = [1, 0, -1, 0, -2, 2],和 target = 0。 滿足要求的四元組集合為:
[
[-1, 0, 0, 1],
[-2, -1, 1, 2],
[-2, 0, 0, 2]
]

思路:和三數之和求解類似,排序+雙指標,只不過多了一層迴圈,第二層迴圈判重,b從 a+1 開始。

程式碼:

class Solution {
public:
    vector<vector<int>> fourSum(vector<int>& nums, int target) {
        int a, b, c, d, len = nums.size(), sum, temp;
        vector<vector<int>> result;
        vector<int> out;
        sort(nums.begin(), nums.end());
        for(a = 0
; a<len; a++) { if(a>0&&nums[a]==nums[a-1]) continue; for(b = a+1; b<len; b++) { if(b>a+1&&nums[b]==nums[b-1]) continue; sum = target-nums[a]-nums[b]; c
= b+1; d = len -1; while(c<d) { temp = nums[c]+nums[d]; if(temp<sum) { c++; } else if(temp>sum) { d--; } else { out.clear(); out.push_back(nums[a]); out.push_back(nums[b]); out.push_back(nums[c]); out.push_back(nums[d]); result.push_back(out); c++; d--; } } } } result.erase(unique(result.begin(), result.end()), result.end()); return result; } };