Loading

【leetcode】15. 3 Sum 双指针 压缩搜索空间

  Given an integer array nums, return all the triplets [nums[i], nums[j], nums[k]] such that i != j, i != k, and j != k, and nums[i] + nums[j] + nums[k] == 0. Notice that the solution set must not contain duplicate triplets.

  

class Solution {
public:
    vector<vector<int>> threeSum(vector<int>& nums) {
        
        vector<vector<int>> res={};
        
        if(nums.size()<3) return res;
        // 暴力发 o(n3) cn/3 如何抽取这三个元素
        // 如何保证插入的元素 不重复 多用set
        // 双指针的改进版本 这个题目 有点意思
        sort(nums.begin(),nums.end());// 压缩搜索空间
        set<vector<int>> dp;
        
        int n=nums.size();
        for(int i=0;i<n;++i){
            int left=i+1;
            int right=n-1;
            while(left<right){
                if((nums[i]+nums[left]+nums[right])==0){
                    dp.insert({nums[i],nums[left],nums[right]});
                    left++;
                    right--;
                }
                else if((nums[i]+nums[left]+nums[right])<0){
                    left++;
                }
                else if((nums[i]+nums[left]+nums[right])>0){
                    right--;
                }
                
            }
        }
        for(auto dd:dp){
            res.push_back(dd);
        }
        return res;
        
        
    }
};

 

posted @ 2021-11-20 14:08  aalanwyr  阅读(24)  评论(0编辑  收藏  举报