当前位置: 首页 > news >正文

优选算法训练篇08--力扣15.三数之和(难度中等)

目录

1.题目链接:15.三数之和

2.题目描述:

3.解法(排序+双指针)


1.题目链接:15.三数之和

2.题目描述:
 

给你一个整数数组 nums ,判断是否存在三元组 [nums[i], nums[j], nums[k]] 满足 i != ji != k 且 j != k ,同时还满足 nums[i] + nums[j] + nums[k] == 0 。请你返回所有和为 0 且不重复的三元组。

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

示例 1:

输入:nums = [-1,0,1,2,-1,-4]
输出:[[-1,-1,2],[-1,0,1]]
解释:
nums[0] + nums[1] + nums[2] = (-1) + 0 + 1 = 0 。
nums[1] + nums[2] + nums[4] = 0 + 1 + (-1) = 0 。
nums[0] + nums[3] + nums[4] = (-1) + 2 + (-1) = 0 。
不同的三元组是 [-1,0,1] 和 [-1,-1,2] 。
注意,输出的顺序和三元组的顺序并不重要。

示例 2:

输入:nums = [0,1,1]
输出:[]
解释:唯一可能的三元组和不为 0 。

示例 3:

输入:nums = [0,0,0]
输出:[[0,0,0]]
解释:唯一可能的三元组和为 0 。

3.解法(排序+双指针)

算法思路:
这题与链接题目相似优选算法训练篇07--力扣LCR179.查找总价格为目标值的两个商品。

稍微不同的是,题目种要求找到所有不重复的三元组。那我们可以利用在两数之和哪里用的双指针思想,来对我们的暴力枚举做优化:

  1. 先排序;
  2. 然后固定一个数a
  3. 在这个数后面的区间内,使用双指针算法快速找到两个数之和等于-a即可。

但是要注意的是,这道题里面需要有去重操作

  1. 找到一个结果之后,left和right指针要跳过重复的元素;
  2. 当使用完一个双指针算法之后,固定的a也要跳过重复的元素。
class Solution {
public:
    vector<vector<int>> threeSum(vector<int>& nums) {
       //1.排序
        sort(nums.begin(),nums.end());
        vector<vector<int>> ret;
        //2.利用指针来解决问题
        int n = nums.size();
        for(int i = 0;i<n;)//固定a
        {
            if(nums[i]>0)break;//小优化,毕竟两个正数相加无论如何也能使一个正数变成0
            int left = i+1,right = n-1,target = -nums[i];
            while(left<right)
            {
                int sum = nums[left] + nums[right];
                if(sum > target)right--;
                else if(sum < target)left++;
                else
                {
                    ret.push_back({nums[i],nums[left],nums[right]});
                    left++, right--;
                    //3.去重操作left和right
                    while(left < right && nums[left-1] == nums[left])
                    left++;
                    while(left < right && nums[right+1] == nums[right])
                    right--;
                }
            }
            //去重i
            i++;
            while(i<n && nums[i-1]==nums[i])
            i++;
        }
        return ret;
    }
};

相关文章:

  • 第4章 IP网络扫描(网络安全评估)
  • 【科研杂记_10】国家行政区划可视化
  • [特殊字符][特殊字符][特殊字符][特殊字符][特殊字符][特殊字符]壁紙 流光染墨,碎影入梦
  • C++基础 [十二] - 继承与派生
  • SpringSecurity——前后端分离登录状态如何保持
  • 【Vitis AI】FPGA设备使用PyTorch 运行 ResNet18获得10000fps
  • 直接插入排序和折半插入排序
  • LeetCode 2517礼盒的最大甜蜜度
  • Linux中,常用的快捷键分类整理(欢迎补充噢)
  • 网络华为HCIA+HCIP IPv6
  • 深入解析文本词汇处理代码——如何用有限词表实现无限表达
  • mysql 磐维(opengauss)tidb误删数据之高级恢复
  • 文献阅读篇#2:YOLO改进类的文章如何高效进行文献阅读(对于初学者)
  • 纯vue手写流程组件
  • cursor无限续杯软件操作教程
  • HWHVV护网入门基础知识
  • 在图片上高亮标注区域
  • LeetCode两数之和
  • Flink CEP:复杂事件处理详解
  • OpenHarmony和HarmonyOS到底有什么区别?
  • 国家卫生健康委通报关于肖某引发舆情事件调查处置进展情况
  • 最高人民法院原副院长唐德华逝世,享年89岁
  • 《上海市建筑信息模型技术应用指南(2025版)》发布
  • 中科飞测将投资超10亿元,在上海张江成立第二总部
  • 乌拉圭前总统何塞·穆希卡去世
  • 美国政府信用卡被设1美元限额,10美元采购花一两小时填表