1 Star 0 Fork 0

xiangxiang/LeetCode-NOTES

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
solution.cpp 1.30 KB
一键复制 编辑 原始数据 按行查看 历史
默然 提交于 7年前 . update all algorithms.
class Solution
{
public:
vector<vector<int> > threeSum(vector<int> &num)
{
vector<vector<int> > result;
if(num.size() == 0)
return result;
sort(num.begin(),num.end());
for( int pos1 = 0;pos1<num.size();pos1++)
{
for(int pos2 = pos1 + 1, pos3 = num.size() - 1; pos2 < pos3;)
{
int sum = num[pos1] + num[pos2] + num[pos3];
if(sum == 0)
{
vector<int> tempResult;
tempResult.push_back(num[pos1]);
tempResult.push_back(num[pos2]);
tempResult.push_back(num[pos3]);
result.push_back(tempResult);
while( pos2+1 < pos3 && num[pos2+1] == num[pos2])
pos2++;
pos2++;
while( pos3-1 > pos2 && num[pos3-1] == num[pos3])
pos3--;
pos3--;
}
else if(sum < 0)
pos2++;
else
pos3--;
}
while( pos1+1 < num.size() && num[pos1+1] == num[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

搜索帮助