【力扣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;
    }
};
相关推荐
NAGNIP7 小时前
一文搞懂深度学习中的通用逼近定理!
人工智能·算法·面试
颜酱16 小时前
单调栈:从模板到实战
javascript·后端·算法
CoovallyAIHub19 小时前
仿生学突破:SILD模型如何让无人机在电力线迷宫中发现“隐形威胁”
深度学习·算法·计算机视觉
CoovallyAIHub19 小时前
从春晚机器人到零样本革命:YOLO26-Pose姿态估计实战指南
深度学习·算法·计算机视觉
CoovallyAIHub19 小时前
Le-DETR:省80%预训练数据,这个实时检测Transformer刷新SOTA|Georgia Tech & 北交大
深度学习·算法·计算机视觉
CoovallyAIHub19 小时前
强化学习凭什么比监督学习更聪明?RL的“聪明”并非来自算法,而是因为它学会了“挑食”
深度学习·算法·计算机视觉
CoovallyAIHub20 小时前
YOLO-IOD深度解析:打破实时增量目标检测的三重知识冲突
深度学习·算法·计算机视觉
NAGNIP1 天前
轻松搞懂全连接神经网络结构!
人工智能·算法·面试
NAGNIP1 天前
一文搞懂激活函数!
算法·面试
董董灿是个攻城狮1 天前
AI 视觉连载7:传统 CV 之高斯滤波实战
算法