18. 4Sum -- 找到数组中和为target的4个数
Given an array S of n integers, are there elements a, b, c, 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: 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],
[-2, -1, 1, 2],
[-2, 0, 0, 2]
]
class Solution {
public:
    vector<vector<int>> fourSum(vector<int>& nums, int target) {
        int l = nums.size(), sum, left, right, i, j;
        vector<vector<int>> ans;
        if (l<)
            return ans;
        sort(nums.begin(), nums.end());
        for (i = ; i<l - ; i++)
        {
            if(i && nums[i] == nums[i-])
                continue;
            for (j = i + ; j<l - ; j++)
            {
                if(nums[i]+nums[j]+nums[j+]+nums[j+]>target)
                    break;
                if(nums[i]+nums[j]+nums[l-]+nums[l-]<target)
                    continue;
                if (j>i +  && nums[j] == nums[j - ])
                    continue;
                sum = nums[i] + nums[j];
                left = j + ;
                right = l - ;
                while (left < right)
                {
                    if (sum + nums[left] + nums[right] == target)
                        ans.push_back({ nums[i], nums[j], nums[left++], nums[right--] });
                    else if (sum + nums[left] + nums[right] < target)
                        left++;
                    else
                        right--;
                    while (left>j+ && nums[left] == nums[left - ])
                        left++;
                    while(right<l- && nums[right] == nums[right + ])
                        right--;
                }
            }
        }
        return ans;
    }
};
18. 4Sum -- 找到数组中和为target的4个数的更多相关文章
- (回溯法)数组中和为S的N个数
		Given a list of numbers, find the number of tuples of size N that add to S. for example in the list ... 
- 给定一个整数数组和一个目标值,找出数组中和为目标值的两个数 例如给定nums = [2,7,11,15],target = 9
		python解决方案 nums = [1,2,3,4,5,6] #假如这是给定的数组 target = 9 #假如这是给定的目标值 num_list = [] #用来装结果的容器 def run(nu ... 
- 【算法习题】正整数数组中和为sum的任意个数的组合数
		1.递归实现(参考:https://blog.csdn.net/hit_lk/article/details/53967627) public class Test { @org.junit.Test ... 
- Two sum(给定一个无重复数组和目标值,查找数组中和为目标值的两个数,并输出其下标)
		示例: nums = [1,2,5,7] target = [6] return [0,2] Python解决方案1: def twoSum(nums, target): ""&q ... 
- LeetCode 18 4Sum (4个数字之和等于target)
		题目链接 https://leetcode.com/problems/4sum/?tab=Description 找到数组中满足 a+b+c+d=0的所有组合,要求不重复. Basic idea is ... 
- 1. Two Sum&&15. 3Sum&&18. 4Sum
		题目: 1. Two Sum Given an array of integers, return indices of the two numbers such that they add up t ... 
- 15. 3Sum、16. 3Sum Closest和18. 4Sum
		15 3sum Given an array nums of n integers, are there elements a, b, c in nums such that a + b + c = ... 
- leetcode 1.Two Sum 、167. Two Sum II - Input array is sorted  、15. 3Sum  、16. 3Sum Closest  、 18. 4Sum 、653. Two Sum IV - Input is a BST
		1.two sum 用hash来存储数值和对应的位置索引,通过target-当前值来获得需要的值,然后再hash中寻找 错误代码1: Input:[3,2,4]6Output:[0,0]Expecte ... 
- [LeetCode][Python]18: 4Sum
		# -*- coding: utf8 -*-'''__author__ = 'dabay.wang@gmail.com' 18: 4Sumhttps://oj.leetcode.com/problem ... 
随机推荐
- 【转载】跟着9张思维导图学习JavaScript
			原文:跟着9张思维导图学习JavaScript 学习的道路就是要不断的总结归纳,好记性不如烂笔头,so,下面将 po 出我收集的 9 张 JavaScript相关的思维导图(非原创). 思维导图小ti ... 
- Django基础-过滤器
			1.可以通过过滤器来修改变量的显示,过滤器的形式是:{{ variable | filter }},管道符号'|'代表使用过滤器 2.过滤器能够采用链式的方式使用,例如:{{ text | escap ... 
- linux中mysql基本操作
			1.linux下启动mysql的命令: mysqladmin start /ect/init.d/mysql start (前面为mysql的安装路径) 2.linux下重启mysql的命令: mys ... 
- oracle默认管理员的帐号和密码以及密码修改和解除锁定
			安装 ORACLE 时,若没有为下列用户重设密码,则其默认密码如下: 用户名 / 密码 登录身份 说明 sys/change_on_install SYSDBA 或 SYSOPER 不能以 NORMA ... 
- git泄漏原理
			之前做过git的加固 但是这东西还是没办法避免的 之前看了乌云的提交的git泄漏,但是都没有详细的原理,去了lijiejie的博客(字太难打了,大师傅别打我 哈哈) 如果一个网站存在git泄漏,git ... 
- Spring的核心机制——依赖注入(Dependency Inject)
			Spring不仅提供对象,还提供对象的属性值,而不是由使用该对象的程序所提供的. Java应用是由一些相互协作的对象所组成的,在Spring中这种相互协作的关系就叫依赖关系. 如果A组件调用了B组件的 ... 
- underscore的封装和扩展
			// 1. 不污染全局环境 (function() { // 2. 保留之前同名变量 var previousUnderscore = window._; var _ = function(obj) ... 
- luabind 导出string问题
			luabind导出字符串 不能导出char* 会有问题 应该是字符串连接的时候出错了 static _TCHAR* pRetChar = new _TCHAR[10]; memcpy(pRetChar ... 
- jQuery中的遍历
			在原生javascript中我们用的最多的遍历就是for,但是在jQuery里面有个方法比for还有强大,它就是我们经常看到的each()方法,当然了如果考虑性能方面的话还是建议用for来进行元素的遍 ... 
- 控制反转和spring在项目中可以带来的好处
			Spring实例化Bean的三种方式分别是: 1,xml配置使用bean的类构造器 <bean id="personService" class="cn.servi ... 
