1).2sum

1.题意:找出数组中和为target的所有数对

2.思路:排序数组,然后用两个指针i、j,一前一后,计算两个指针所指内容的和与target的关系,如果小于target,i右移,如果大于,j左移,否则为其中一个解

3.时间复杂度:O(nlgn)+O(n)

4.空间:O(1)

5.代码:

    void twoSum(vector<int>& nums,int numsSize,int target,vector<vector<int>>& twoSumRes) {
int i=0,j=numsSize-;
while(i<j){
if(nums[i]+nums[j] < target ){
i++;
}else if(nums[i]+nums[j] > target ){
j--;
}else{
vector<int> oneOfRes;
oneOfRes.push_back(nums[i]);
oneOfRes.push_back(nums[j]);
twoSumRes.push_back(oneOfRes);
i++;
/* 找不重复的数对 */
while(nums[i]==nums[i-])i++;
j--;
/* 找不重复的数对 */
while(nums[j]==nums[j+])j--;
}
}
}

2).3sum

1.题意:找出数组中和为target的所有三个数的组合,任意两个组合中的元素不能全相同,例如,target=5,2,2,1和1,2,2就是重复的组合,因为两个组合中的元素完全相同,只能取其中的一个。

2.思路:这个题可以转换题意,取数组中的一个元素a,求剩余元素中和为target-a的所有不重复数对,转换为2Sum问题。

3.时间复杂度:O(nlgn)+O(n*n)

4.空间:O(1)

5.代码:

class Solution {
public:
void twoSum(vector<int>& nums,int numsSize,int start,int target,vector<vector<int>>& twoSumRes) {
int i=start,j=numsSize-;
while(i<j){
if(nums[i]+nums[j] < target ){
i++;
}else if(nums[i]+nums[j] > target ){
j--;
}else{
vector<int> oneOfRes;
oneOfRes.push_back(nums[i]);
oneOfRes.push_back(nums[j]);
twoSumRes.push_back(oneOfRes);
i++;
while(nums[i]==nums[i-])i++;
j--;
while(nums[j]==nums[j+])j--;
}
}
}
vector<vector<int>> threeSum(vector<int>& nums) {
size_t nums_size = nums.size();
vector<vector<int>> res;
sort(nums.begin(),nums.end());
for(size_t i=;i<nums_size;i++){
if(i> && (nums[i]==nums[i-])){
continue;
}
vector<vector<int>> twoSumRes ;
twoSum(nums,nums_size,i+,-nums[i],twoSumRes);
if(!twoSumRes.empty()){
size_t j_times = twoSumRes.size();
for(size_t j=;j<j_times;j++){
twoSumRes[j].insert(twoSumRes[j].begin(),nums[i]);
res.push_back(twoSumRes[j]);
}
}
}
return res;
}
};

3).4Sum,kSum

1.题目:求所有和为target的4个元素的不重复组合,任意两个组合中的元素不能全相同。

2.思路:递归,4Sum->3Sum->2Sum

3.时间复杂度:O(nlgn)+O(n*n*...*n),k-1个n

代码:

class Solution {
public:
vector<vector<int>> towSum(vector<int>& nums,int numsSize,int start,int target)
{
vector<vector<int>> res;
int i = start,j=numsSize-;
while(i<j){
if(nums[i] + nums[j] < target){
i++;
}else if(nums[i] + nums[j] > target){
j--;
}else{
vector<int> item;
item.push_back(nums[i]);
item.push_back(nums[j]);
res.push_back(item);
i++;
while(nums[i]==nums[i-])i++;
j--;
while(nums[j]==nums[j+])j--;
}
}
return res;
} vector<vector<int>> kSum(vector<int>& nums,int numsSize,int start,int k,int target)
{
if(k==){
return towSum(nums, numsSize, start, target);
}else{
vector<vector<int>> kSumRes;
for(size_t i=start;i<numsSize;i++){
if(i>start && (nums[i]==nums[i-])){
continue;
} vector<vector<int>> item = kSum(nums,numsSize,i+,k-,target-nums[i]);
size_t itemSize = item.size();
for(size_t j=;j<itemSize;j++){
item[j].insert(item[j].begin(),nums[i]);
kSumRes.push_back(item[j]);
}
}
return kSumRes;
}
}
vector<vector<int>> fourSum(vector<int>& nums, int target) {
sort(nums.begin(),nums.end());
size_t numsSize = nums.size();
return kSum(nums,numsSize,,,target);
}
};

4).类似的题,3Sum Closest

1.题目:

Given an array S of n integers, find three integers in S such that the sum is closest to a given number, target. Return the sum of the three integers. You may assume that each input would have exactly one solution.

    For example, given array S = {-1 2 1 -4}, and target = 1.

    The sum that is closest to the target is 2. (-1 + 2 + 1 = 2).

2.时间:O(nlgn)+O(n*m*2),m*2表示试探次数

3.代码

class Solution {
public:
bool twoSum(vector<int>& nums,int numsSize,int start,int target)
{
int i=start,j=numsSize-;
while(i<j){
if(nums[i] + nums[j] < target){
i++;
}else if(nums[i] + nums[j] > target){
j--;
}else{
return true;
}
}
return false;
}
int threeSumClosest(vector<int>& nums, int target) {
sort(nums.begin(),nums.end());
size_t numsSize = nums.size();
int increasment = ;
while(true){
bool hasTwoSum = false;
for(size_t i=;i<nums.size();i++){
hasTwoSum = twoSum(nums,numsSize,i+,target+increasment-nums[i]);
if(hasTwoSum){
break;
}
hasTwoSum = twoSum(nums,numsSize,i+,target-increasment-nums[i]);
if(hasTwoSum){
increasment = -increasment;
break;
}
}
if(hasTwoSum){
break;
}
increasment++;
}
return target+increasment;
}
};

5).后序:

这类题的算法原型就是2Sum,在求不重复的数对时,有个小技巧(排好序的基础上),就是在求得arry[i]+arry[j] == target时,要去掉与arry[i]和arry[j]相等的元素。

这种使用两个指针处理数组的方法也很常见,例如,排序颜色数组,奇数偶数分类,有序数组中连续子数组和为target的所有组合等等

2Sum,3Sum,4Sum,kSum,3Sum Closest系列的更多相关文章

  1. 求和问题总结(leetcode 2Sum, 3Sum, 4Sum, K Sum)

    转自  http://tech-wonderland.net/blog/summary-of-ksum-problems.html 前言: 做过leetcode的人都知道, 里面有2sum, 3sum ...

  2. LeetCode Two Sum&Two Sum II - Input array is sorted&3Sum&4Sum 一锅煮题解

    文章目录 Two Sum Two Sum II 3Sum 4Sum Two Sum 题意 给定一个数组,和指定一个目标和.从数组中选择两个数满足和为目标和.保证有且只有一个解.每个元素只可以用一次. ...

  3. 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 ...

  4. LeetCode解题报告--2Sum, 3Sum, 4Sum, K Sum求和问题总结

    前言: 这几天在做LeetCode 里面有2sum, 3sum(closest), 4sum等问题, 这类问题是典型的递归思路解题.该这类问题的关键在于,在进行求和求解前,要先排序Arrays.sor ...

  5. 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 = ...

  6. 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 ...

  7. 秒杀 2Sum 3Sum 4Sum 算法题

    2 Sum 这题是 Leetcode 的第一题,相信大部分小伙伴都听过的吧. 作为一道标着 Easy 难度的题,它真的这么简单吗? 我在之前的刷题视频里说过,大家刷题一定要吃透一类题,为什么有的人题目 ...

  8. 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 ...

  9. 3Sum,4Sum问题

    //三数和为0的问题.要求去重,并且输出数字有序.public List<List<Integer>> threeSum(int[] nums) { Arrays.sort(n ...

随机推荐

  1. Xcode 中添加 .pch文件

    1  新建工程 2  创建  .pch文件 3   在setting里面进行设置:

  2. OC中限制UITextView的最大字数的实现

    一.属性 //自定义的textview @property (weak, nonatomic) IBOutlet UITextView *textview; //添加一个bool类型的属性 @prop ...

  3. 【设计模式:单例模式】使用单例模式加载properties文件

    先准备测试程序: package org.jediael.util; import static org.junit.Assert.*; import org.junit.Test; public c ...

  4. js原生Ajax的封装与使用

    一.原生Ajax代码的封装如下: (function() { var XHR = { createStandardXHR: function() { return new XMLHttpRequest ...

  5. 快速下单!简化EcStore的购物结算流程

    EcStore拥有完善的购物车功能,方便顾客浏览挑选商品,但是在提交订单时必须要求用户先登录注册 如果是未注册用户还多出一个注册用户的步骤这些多出来的步骤和操作会影响购物下单的流畅性,降低了用户购物下 ...

  6. SQL Server 索引的自动维护 <第十三篇>

    在有大量事务的数据库中,表和索引随着时间的推移而碎片化.因此,为了增进性能,应该定期检查表和索引的碎片,并对具有大量碎片的进行整理. 1.确定当前数据库中所有需要分析碎片的表. 2.确定所有表和索引的 ...

  7. C# 多线程的自动管理(线程池) 基于Task的方式

    C# 多线程的自动管理(线程池) 在多线程的程序中,经常会出现两种情况:    1. 应用程序中线程把大部分的时间花费在等待状态,等待某个事件发生,然后给予响应.这一般使用 ThreadPool(线程 ...

  8. Go代理,修改标题

  9. java实现文件编码监测

    java实现文件编码监测 最近在做一个文档的翻译项目,可文档的编码不知道,听头疼的.尝试了很多方法最后发现JCharDet这个工具可以轻松解决这个问题.于是作此笔记希望日后提醒自己以及帮助又需要的人. ...

  10. 软件体系结构经典问题——KWIC的分析和解决

    KWIC作为一个早年间在ACM的Paper提出的一个问题,被全世界各个大学的软件设计课程奉为课堂讲义或者作业的经典.(From Wiki,FYI,D. L. Parnas uses a KWIC In ...