双指针法 ( 三数之和 )

题目  :给你一个整数数组 nums ,判断是否存在三元组 [nums[i], nums[j], nums[k]] 满足 i != ji != k 且 j != k ,同时还满足 nums[i] + nums[j] + nums[k] == 0 。请

你返回所有和为 0 且不重复的三元组。

注意:答案中不可以包含重复的三元组。

在解决这一问题中,我们需要用到相向双指针。

首先需要对数组nums 排好序,便于之后的各种操作。

从数组第一个数num[now] 开始向后遍历, 如果now now+1 now+2 三个数和大于0,在这种情况下,当前剩下的最小的三个数和仍大于0,那么便没有能使之后的数的和都大于0,结束循环;同样,如果now end end-1 三个数的和小于0,在这种情况下,当前数 与剩下的最大的两个数和仍小于0,那么便没有能使之后的数的和都小于0,now++,进行下一次判断;如果num[now] 与上一个数相同,now++,进行下一次判断。 将数组排序好的好处之一便在此。需要注意的是,now 在整个循环中应当小于 size - 2 ,因为最少应剩下三个数。

在有一个符合上述条件的now 时:

            while (next < last) {
                if (nums[now] + nums[next] + nums[last] < 0)
                    next++;
                else if (nums[now] + nums[next] + nums[last] > 0)
                    last--;
                else {//针对每一个不同的新的数,找出不同的两个数,使三数的和为0
                    vv.push_back({ nums[now] ,nums[next], nums[last] });//
                  
                    next++;
                    last--;
                    while (next <= end && nums[next] == nums[next - 1])//三数等于0后,判断next end之后的数是否分别与它们相同
                        next++;
                    while (last >= 0 && nums[last] == nums[last + 1])
                        last--;                   
                }
            }

class Solution {
public: 
    vector<vector<int>> threeSum(vector<int>& nums) {
        vector<vector<int>> vv;
        sort(nums.begin(),nums.end());
        
        int now = 0;
        while (now < nums.size() - 2) {
            int end = nums.size() - 1;

            if (now != 0 && nums[now] == nums[now - 1])
            {
                now++;
                continue;
            }
            if (nums[now] + nums[now + 1] + nums[now + 2] > 0)
                break;
            if (nums[now] + nums[end] + nums[end - 1] < 0)
            {
                now++;
                continue;
            }
            int next = now + 1;
            int last = end;
            while (next < last) {
                if (nums[now] + nums[next] + nums[last] < 0)
                    next++;
                else if (nums[now] + nums[next] + nums[last] > 0)
                    last--;
                else {//针对每一个不同的新的数,找出不同的两个数,使三数的和为0
                    vv.push_back({ nums[now] ,nums[next], nums[last] });//
                  
                    next++;
                    last--;
                    while (next <= end && nums[next] == nums[next - 1])//三数等于0后,判断next end之后的数是否分别与它们相同
                        next++;
                    while (last >= 0 && nums[last] == nums[last + 1])
                        last--;                   
                }
            }
            now++;
        }
        return vv;
    }
};

相关推荐

  1. Golang 之和+ 四之和 leetcode15、18 指针

    2024-06-05 21:06:03       35 阅读
  2. 指针 Leetcode 15 之和

    2024-06-05 21:06:03       12 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-06-05 21:06:03       14 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-06-05 21:06:03       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-06-05 21:06:03       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-06-05 21:06:03       18 阅读

热门阅读

  1. Qt程序发布工具windeployqt.exe所带来的坑

    2024-06-05 21:06:03       7 阅读
  2. C++中的List

    2024-06-05 21:06:03       6 阅读
  3. x264 参考帧管理原理:i_frame_num 变量

    2024-06-05 21:06:03       8 阅读
  4. Web前端框架:深入探索与实践

    2024-06-05 21:06:03       6 阅读
  5. AndroidStudio设置允许APP获取定位权限

    2024-06-05 21:06:03       7 阅读
  6. 算法题day37日(补5.23日卡:贪心算法day4)

    2024-06-05 21:06:03       7 阅读
  7. rman reset database incarnation 重建controlfile

    2024-06-05 21:06:03       8 阅读
  8. mac 安装mvn 、node 、vue

    2024-06-05 21:06:03       8 阅读
  9. R语言数据分析15-xgboost模型预测

    2024-06-05 21:06:03       7 阅读
  10. NXP RT1060学习总结 - 基础CAN功能

    2024-06-05 21:06:03       8 阅读
  11. SpringMVC:获取请求数据

    2024-06-05 21:06:03       7 阅读