15. 三数之和
This commit is contained in:
28
test006.cpp
Normal file
28
test006.cpp
Normal file
@@ -0,0 +1,28 @@
|
|||||||
|
class Solution {
|
||||||
|
public:
|
||||||
|
vector<vector<int>> threeSum(vector<int>& nums) {
|
||||||
|
// Ö÷ÒªÎÊÌ⻹ÊÇÈ¥ÖØ¸´
|
||||||
|
int n = nums.size();
|
||||||
|
sort(nums.begin(), nums.end());
|
||||||
|
vector<vector<int>> ret;
|
||||||
|
int preid = -1;
|
||||||
|
for(int i = 0; i < n; i++){
|
||||||
|
if(preid != -1 && nums[i] == nums[preid]) continue;
|
||||||
|
int l = i + 1, r = n - 1;
|
||||||
|
while(l < r){
|
||||||
|
int sum = nums[i] + nums[l] + nums[r];
|
||||||
|
if(sum == 0){
|
||||||
|
ret.push_back({nums[l], nums[r], nums[i]});
|
||||||
|
int tmp = nums[l];
|
||||||
|
while(l < r && nums[l] == tmp) l++;
|
||||||
|
preid = i;
|
||||||
|
}else if(sum > 0){
|
||||||
|
r--;
|
||||||
|
}else{
|
||||||
|
l++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
};
|
||||||
Reference in New Issue
Block a user