//题目: 给定一个包含 n 个整数的数组 nums,判断 nums 中是否存在三个元素 a,b,c ,使得 a + b + c = 0?找出所有满足条件且不重复的三元组。
//注意:答案中不可以包含重复的三元组。
//
//问题函数定义:
//cpp
//vector<vector<int>> threeSum(vector<int>&nums);
//使用先选取一个元素,再使用双指针法
//裁判测试程序样例:
//cpp
#include <iostream>
#include <vector>
#include<algorithm>
using namespace std;
vector<vector<int>> threeSum(vector<int>& nums) {
vector<vector<int>> d;
vector<int> a = nums;
sort(a.begin(), a.end());
for (int i = 0; i < a.size(); i++) {
if (i > 0 && a[i] == a[i - 1]) {
continue;
}
int lef = i + 1;
int rig = a.size() - 1;