leetcode 15 3sum & leetcode 18 4sum
3sum:
1 class Solution {
public:
vector<vector<int>> threeSum(vector<int>& nums) {
vector<vector<int>>result;
vector<vector<int>>::iterator iter;
vector<int>Middle;
int length=nums.size()-;
sort(nums.begin(),nums.end());
for(int i=;i<length-;i++) {
int st=i+,en=length;
if(i>&&nums[i]==nums[i-])continue;
while(st<en) {
while(st>i+&&nums[st-]==nums[st]) {
st++;
continue;
}
while(en<length&&nums[en+]==nums[en]) {
en--;
continue;
}
if(st>=en)break;
int temp=nums[st]+nums[en];
if(temp+nums[i]==) {
Middle.push_back(nums[i]);
Middle.push_back(nums[st]);
Middle.push_back(nums[en]);
result.push_back(Middle);
Middle.clear();
st++;
}
else
if(temp+nums[i]<)
st++;
else
if(temp+nums[i]>)
en--;
}
}
return result;
}
};
4sum:
class Solution {
public:
vector<vector<int>> fourSum(vector<int>& nums, int target) {
vector<vector<int>> result;
vector<int>MiddResult;
if(nums.size()<)return result;
sort(nums.begin(),nums.end());
int length=nums.size();
for(int i=;i<length-;i++) {
if(i>&&nums[i]==nums[i-])continue;
for(int j=i+;j<length-;j++) {
if(j>i+&&nums[j]==nums[j-])continue;
int st=j+,en=length-;
while(st<en) {
if(st>j+&&nums[st-]==nums[st]) {
st++;
continue;
}
if(en<length-&&nums[en+]==nums[en]) {
en--;
continue;
}
int temp=nums[i]+nums[j]+nums[st]+nums[en];
if(temp==target) {
MiddResult.push_back(nums[i]);
MiddResult.push_back(nums[j]);
MiddResult.push_back(nums[st]);
MiddResult.push_back(nums[en]);
result.push_back( MiddResult);
st++;
MiddResult.clear();
}
else
if(temp<target)
st++;
else en--;
}
}
}
return result;
}
};
leetcode 15 3sum & leetcode 18 4sum的更多相关文章
- 查找表,Two Sum,15. 3Sum,18. 4Sum,16 3Sum Closest,149 Max points on line
Two Sum: 解法一:排序后使用双索引对撞:O(nlogn)+O(n) = O(nlogn) , 但是返回的是排序前的指针. 解法二:查找表.将所有元素放入查找表, 之后对于每一个元素a,查找 t ...
- LeetCode 15 3Sum [sort] <c++>
LeetCode 15 3Sum [sort] <c++> 给出一个一维数组,找出其中所有和为零的三元组(元素集相同的视作同一个三元组)的集合. C++ 先自己写了一发,虽然过了,但跑了3 ...
- LeetCode 15. 3Sum 16. 3Sum Closest 18. 4Sum
n数求和,固定n-2个数,最后两个数在连续区间内一左一右根据当前求和与目标值比较移动,如果sum<target,移动较小数,否则,移动较大数 重复数处理: 使i为左至右第一个不重复数:while ...
- leetcode 15. 3Sum 二维vector
传送门 15. 3Sum My Submissions Question Total Accepted: 108534 Total Submissions: 584814 Difficulty: Me ...
- [LeetCode] 15. 3Sum 三数之和
Given an array S of n integers, are there elements a, b, c in S such that a + b + c = 0? Find all un ...
- LeetCode——15. 3Sum
一.题目链接:https://leetcode.com/problems/3sum/ 二.题目大意: 3和问题是一个比较经典的问题,它可以看做是由2和问题(见http://www.cnblogs.co ...
- LeetCode 15 3Sum(3个数求和为0的组合)
题目链接 https://leetcode.com/problems/3sum/?tab=Description Problem: 给定整数集合,找到所有满足a+b+c=0的元素组合,要求该组合不 ...
- LeetCode 15. 3Sum(三数之和)
Given an array S of n integers, are there elements a, b, c in S such that a + b + c = 0? Find all un ...
- leetCode 15. 3Sum (3数之和) 解题思路和方法
3Sum Given an array S of n integers, are there elements a, b, c in S such that a + b + c = 0? Find ...
随机推荐
- Activiti学习记录(二)
1.初始化数据库 使用工作流引擎创建23张表 public class TestActiviti { /** * 使用代码创建工作流需要的23张表 */ @Test public void creat ...
- AngularJS最佳实践
1.依赖注入不要用推断式 2.双向绑定的变量设置成$scope下的一个对象的属性 3.多个控制器之间的通信尽量使用service实现,不要使用全局变量或者$rootScope 4.尽量不在控制器中操作 ...
- 【转】 bind1st bind2nd的使用
以前在使用stl的过程中发现bind1st和bind2nd这两个函数,当时不太理解什么意思,今天在网上查了一下相关资料发现竟然很简单,下面我就具体解释一下他们的用法. bind1st和bind2nd函 ...
- C++ 无限定名称查找
无限定名称查找 (关键字:懒惰,挑捡,using指令的特殊性) 无限定名称查找实际上就是指没有限定(名称空间和名称空间运算符)名存在的一个名字的出现,其中对于using指令,其内部包含的所有的声明是被 ...
- 动态规划:HDU1176-免费馅饼
免费馅饼 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submi ...
- BFS:CF356C-Compartments
C. Compartments time limit per test 1 second memory limit per test 256 megabytes input standard inpu ...
- python实现分布式进程
今天用python实现分布式,基于python2.7,注意:在linux下执行测试通过,在windows测试失败.# -*- coding: utf-8 -*-__author__ = 'dell'i ...
- mysql-show processlist之writing to net
mysql提示Writing to net解决 最近发现某一个数据库cpu占用比较过.超过200%了. 首先查看数据库慢日志,设定慢日志5秒,基本上没有产生日,没有超过5秒的语句. show proc ...
- Kali 中文家目录改英文目录
中文版Kali装好之后,家目录会中文显示,不便操作 root@kali:~# ls -l drwxr-xr-x root root .0K 7月 : 公共 drwxr-xr-x root root . ...
- 洛谷P1328生活大爆炸版石头剪刀布
题目链接:https://www.luogu.org/problemnew/show/P1328