leetcode132:4sum
题目描述
- 四元组(a、b、c、d)中的元素必须按非降序排列。(即a≤b≤c≤d)
- 解集中不能包含重复的四元组。
    例如:给出的数组 S = {1 0 -1 0 -2 2}, 目标值 = 0.↵↵    给出的解集应该是:↵    (-1,  0, 0, 1)↵    (-2, -1, 1, 2)↵    (-2,  0, 0, 2)
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.
    For example, given array S = {1 0 -1 0 -2 2}, and target = 0.↵↵    A solution set is:↵    (-1,  0, 0, 1)↵
class Solution {
public:
    vector<vector<int> > fourSum(vector<int> &num, int target) {
        vector <vector<int>> res;
        vector< int> temp (4,0);
        set<vector<int> > st;
        sort(num.begin(),num.end());
        int n=num.size();
        for (int i=0;i<n;i++){
            for (int j=i+1;j<n;j++){
                int left=j+1,right=n-1;
                while (left<right){
                    int sum=num[i]+num[j]+num[left]+num[right];
                    if (sum==target){
                        temp[0]=num[i];
                        temp[1]=num[j];
                        temp[2]=num[left];
                        temp[3]=num[right];
                        st.insert(temp);
                    }
                    if (sum<target)
                        left++;
                    else 
                        right--;
                }
            }
        }
        set<vector<int>>::iterator it;
        for (it=st.begin();it !=st.end();it++)
            res.push_back(*it);
        return res;
    }
};												
											leetcode132:4sum的更多相关文章
- [LeetCode] 4Sum II 四数之和之二
		Given four lists A, B, C, D of integer values, compute how many tuples (i, j, k, l) there are such t ... 
- [LeetCode] 4Sum 四数之和
		Given an array S of n integers, are there elements a, b, c, and d in S such that a + b + c + d = tar ... 
- LeetCode:3Sum, 3Sum Closest, 4Sum
		3Sum Closest Given an array S of n integers, find three integers in S such that the sum is closest t ... 
- 2016/10/28 很久没更了 leetcode解题 3sum问题进阶版4sum
		18. 4Sum Given an array S of n integers, are there elements a, b, c, and d in S such that a + b + c ... 
- No.018:4Sum
		问题: Given an array S of n integers, are there elements a, b, c, and d in S such that a + b + c + d = ... 
- 6.3Sum  && 4Sum  [ && K sum ] && 3Sum Closest
		3Sum Given an array S of n integers, are there elements a, b, c in S such that a + b + c = 0? Find a ... 
- 3Sum & 4Sum
		3 Sum Given an array S of n integers, are there elements a, b, c in Ssuch that a + b + c = 0? Find a ... 
- 【leetcode】4Sum
		4Sum Given an array S of n integers, are there elements a, b, c, and d in S such that a + b + c + d ... 
- 2sum、3sum、4sum以及任意连续的数的和为sum、任意连续或者不连续的数的和为sum
		2sum 如果数组是无序的,先排序(n*logn),然后用两个指针i,j,各自指向数组的首尾两端,令i=0,j=n-1,然后i++,j--,逐次判断a[i]+a[j]?=sum,如果某一刻a[i]+a ... 
随机推荐
- 最全vue的vue-amap使用高德地图插件画多边形范围
			一.在vue-cli的框架下的main.js(或者main.ts)中引入高德插件,代码如下: import Vue from 'vue' import VueAMap from 'vue-amap' ... 
- ASP。NET Core Blazor CRUD使用实体框架和Web API
			下载source code - 1.7 MB 介绍 *请查看我的Youtube视频链接来学习ASP.NET Core Blazor CRUD使用实体框架和Web API. 在本文中,我们将了解如何为A ... 
- 代码格式化工具:clang-format
			IDE: Visual Studio Code Language: C/C++ 格式化工具: clang-format 安装 vscode安装扩展C/C++,扩展程序将自动安装clang-format ... 
- Python数据类型--集合(set)
			Python的集合是无序.可迭代的容器对象,所有元素放在一对大括号中{},元素之间使用逗号隔开,同一集合内的元素具有唯一性,不允许重复. 集合中只能包含数字.字符串.元组等不可变类型的数据,不能包含列 ... 
- 跨境 TCP 传输优化实录 — 使用 BBR 解决 LFN 问题
			背景 近期开通了一条访问美国机房的 1G 专线,用于提供行情数据备源,并基于 TCP 建立了一套数据传输服务.上线后发现一个严重的问题:应用程序发送队列中的数据大量积压,最终导致程序 OOM Kill ... 
- java字符流与字节流的区别是什么
			java中字符流与字节流的区别: 1.字节流操作的基本单元为字节:字符流操作的基本单元为Unicode码元. 2.字节流默认不使用缓冲区:字符流使用缓冲区. 3.字节流通常用于处理二进制数据,实际上它 ... 
- day32 Pyhton 异常处理
			一.内容回顾 反射的另外两个内置函数 setattr delattr a.b=c 与 setattr(a,'b',c)相对 del a.b 与 delattr(a,'b') 两个内置函数 A,B(A) ... 
- python写文件时遇到UnicodeEncodeError: 'gbk' codec can't encode character的解决方式
			在window平台,文件的默认编码是gbk, 此时如果写入的字符串的编码是utf-8就会引发这种错误,打开文件的编码必须与字符串的编码一致 with open('content.txt','w',en ... 
- 【编程学习笔记】如何组织构建多文件 C 语言程序!编程也有~
			优秀 Unix 程序哲学 首先,你要知道这个 C 程序是一个 Unix 命令行工具.这意味着它运行在(或者可被移植到)那些提供 Unix C 运行环境的操作系统中.当贝尔实验室发明 Unix 后,它从 ... 
- 19。删除链表倒数第N个节点
			class ListNode: def __init__(self, val=0, next=None): self.val = val self.next = next# 这道题还是很简单的,我们只 ... 
