1 Star 0 Fork 0

xiangxiang/LeetCode-NOTES

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
solution.cpp 1.70 KB
一键复制 编辑 原始数据 按行查看 历史
默然 提交于 7年前 . update all algorithms.
class Solution
{
public:
vector<vector<int>> fourSum(vector<int>& nums, int target)
{
vector<vector<int> > result;
if(nums.size() == 0)
return result;
sort(nums.begin(),nums.end());
for( int pos1 = 0;pos1<nums.size();pos1++)
{
for(int pos2 = pos1 + 1;pos2<nums.size();pos2++)
{
for(int pos3 = pos2 + 1, pos4 = nums.size() - 1; pos3 < pos4;)
{
int sum = nums[pos1] + nums[pos2] + nums[pos3] + nums[pos4];
if(sum == target)
{
vector<int> tempResult;
tempResult.push_back(nums[pos1]);
tempResult.push_back(nums[pos2]);
tempResult.push_back(nums[pos3]);
tempResult.push_back(nums[pos4]);
result.push_back(tempResult);
while( pos3+1 < pos4 && nums[pos3+1] == nums[pos3])
pos3++;
pos3++;
while( pos4-1 > pos3 && nums[pos4-1] == nums[pos4])
pos4--;
pos4--;
}
else if(sum < target)
pos3++;
else
pos4--;
}
while( pos2+1 < nums.size() && nums[pos2+1] == nums[pos2])
pos2++;
}
while( pos1+1 < nums.size() && nums[pos1+1] == nums[pos1])
pos1++;
}
return result;
}
};
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/xiangxiang920/LeetCode-NOTES.git
git@gitee.com:xiangxiang920/LeetCode-NOTES.git
xiangxiang920
LeetCode-NOTES
LeetCode-NOTES
master

搜索帮助