【力扣hot100题】(105)三数之和

之前的题都是两个指针,这次要三个指针,但本质上还是双指针。

先按序排列,第一个指针正常从左往右,后两个指针按照双指针的做法,从两端开始向各自逼近。

cpp 复制代码
class Solution {
public:
    vector<vector<int>> threeSum(vector<int>& nums) {
        sort(nums.begin(),nums.end());
        vector<vector<int>> result;
        int n=nums.size();
        for(int one=0;one<n-2&&nums[one]<=0;one++){
            int left=one+1;
            int right=n-1;
            while(left<right){
                if(nums[left]+nums[right]+nums[one]<0) left++;
                else if(nums[left]+nums[right]+nums[one]>0) right--;
                else{
                    result.push_back(vector<int>{nums[one],nums[left],nums[right]});
                    while(left<n-1&&nums[left]==nums[left+1]) left++;
                    left++;
                }
            }
            while(one<n-2&&nums[one]==nums[one+1]) one++;
        }
        return result;
    }
};
相关推荐
探序基因13 小时前
单细胞Seurat数据结构修改分群信息
数据结构
六义义14 小时前
java基础十二
java·数据结构·算法
四维碎片14 小时前
QSettings + INI 笔记
笔记·qt·算法
Tansmjs14 小时前
C++与GPU计算(CUDA)
开发语言·c++·算法
独自破碎E14 小时前
【优先级队列】主持人调度(二)
算法
weixin_4454766815 小时前
leetCode每日一题——边反转的最小成本
算法·leetcode·职场和发展
打工的小王15 小时前
LeetCode Hot100(一)二分查找
算法·leetcode·职场和发展
Swift社区15 小时前
LeetCode 385 迷你语法分析器
算法·leetcode·职场和发展
sonadorje15 小时前
svd在图像处理中的应用
算法
挖矿大亨15 小时前
c++中的函数模版
java·c++·算法