
难度:medium
本题可以看作是2sum的一种延伸,固定一个元素,对其余进行2sum。需要注意的是去除掉重复项和越界问题。代码如下。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36
|
class Solution { public: vector<vector<int> > threeSum(vector<int> &nums) { vector<vector<int> > result; sort(nums.begin(), nums.end()); for (int i = 0; i < nums.size(); i++) { if (i > 0 && nums[i] == nums[i - 1]) { continue; } // two sum; int start = i + 1, end = nums.size() - 1; int target = -nums[i]; while (start < end) { if (start > i + 1 && nums[start - 1] == nums[start]) { start++; continue; } if (nums[start] + nums[end] < target) { start++; } else if (nums[start] + nums[end] > target) { end--; } else { vector<int> triple; triple.push_back(nums[i]); triple.push_back(nums[start]); triple.push_back(nums[end]); result.push_back(triple); start++; } } } return result; } };
|
结果:46 ms,超过67.82%
近期评论