leetcode15:3Sum

这题的意思是,输入一个数组,找出其中和为0的三元组,注意这边的三元组不能重复。
如,给定一个数组 S = [-1, 0, 1, 2, -1, -4],
那么它的解应该为:[-1, 0, 1], [-1, -1, 2]
像这里[-1, 0, 1]和[0, 1, -1]是重复的,所以只能取其中一个。

因为不能有重复,所以先对数组进行排序来处理这个问题。在排序数组中依次不重复的选择一个数,这个数的反作为twoSum的目标数,这里依旧跳过重复数。排序数组遍历完则所有不重复的三元组就得到了。

具体实现如下:

class Solution {
public:
    vector<vector<int>> twoSum(vector<int> nums,int end,int target)
    {
        int start=0;
        vector<vector<int>> ret;
        while(start<end)
        {
            if(nums[start]+nums[end]==target)
            {
                vector<int> curRet;
                curRet.push_back(nums[start]);
                curRet.push_back(nums[end]);
                ret.push_back(curRet);
                start++;
                end--;
                while(start<end&&nums[start]==nums[start-1])
                {
                    start++;
                }
                while(start<end&&nums[end]==nums[end+1])
                {
                    end--;
                }
            }
            else if(nums[start]+nums[end]<target)
            {
                start++;
            }
            else
            {
                end--;
            }
        }
        return ret;
    }

    vector<vector<int>> threeSum(vector<int>& nums) {
        vector<vector<int>> result;
        if(nums.empty())
        {
            return result;
        }
        sort(nums.begin(),nums.end());
        for(int i=nums.size()-1;i>=2;--i)
        {
            if(i<nums.size()-1&&nums[i]==nums[i+1])
            {
                continue;
            }
            vector<vector<int>> curRet=twoSum(nums,i-1,-nums[i]);
            for(int j=0;j<curRet.size();++j)
            {
                curRet[j].push_back(nums[i]);
                result.push_back(curRet[j]);
            }
        }
        return result;
    }
};
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值