leetcode 三数之和_leetcode数组

leetcode 三数之和_leetcode数组原题链接给你一个包含 n 个整数的数组 nums,判断 nums 中是否存在三个元素 a,b,c ,使得 a + b + c = 0 ?请你找出所有和为 0 且不重复的三元组。注意:答案中不可以包含重复的三元组。示例 1:输入:nums = [-1,0,1,2,-1,-4]输出:[[-1,-1,2],[-1,0,1]]示例 2:输入:nums = []输出:[]示例 3:输入:nums = [0]输出:[] 提示:0 <= nums.length <= 300

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

原题链接
给你一个包含 n 个整数的数组 nums,判断 nums 中是否存在三个元素 a,b,c ,使得 a + b + c = 0 ?请你找出所有和为 0 且不重复的三元组。

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

示例 1:

输入:nums = [-1,0,1,2,-1,-4]
输出:[[-1,-1,2],[-1,0,1]]
示例 2:

输入:nums = []
输出:[]
示例 3:

输入:nums = [0]
输出:[]
 

提示:

0 <= nums.length <= 3000
-105 <= nums[i] <= 105

题解
固定a,则 b + c == -a,由此可以想到先排序,然后利用双指针,时间复杂度O(n2)

class Solution { 
   
public:
    vector<vector<int>> threeSum(vector<int>& nums) { 
   
        sort(nums.begin(),nums.end());
        for(int i = 0;i < nums.size();i ++)cout<<nums[i]<<" ";
        vector<vector<int> >res;
        for(int i = 0;i < nums.size();i ++){ 
   
            if(i >= 1 && nums[i] == nums[i - 1])continue;
            int tar = -nums[i];
            for(int j = i + 1,r = nums.size() - 1;j < r;j ++){ 
   
                if(j > i + 1 && nums[j] == nums[j - 1])continue;
                while(r - 1 > j && nums[j] + nums[r - 1] >= tar)r --;
                if(nums[j] + nums[r] == tar)res.push_back({ 
   nums[i],nums[j],nums[r]});
            }
        }
        return res;
    }
};
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/168987.html原文链接:https://javaforall.net

(0)
上一篇 2022年8月9日 上午6:36
下一篇 2022年8月9日 上午6:36


相关推荐

  • 腾讯版“小龙虾”WorkBuddy正式上线

    腾讯版“小龙虾”WorkBuddy正式上线

    2026年3月13日
    1
  • cuda编程-并行规约

    cuda编程-并行规约

    2022年3月8日
    54
  • 灰度测试或 AB 测试

    灰度测试或 AB 测试灰度测试 就是指如果软件要在不久的将来推出一个全新的功能 或者做一次比较重大的改版的话 要先进行一个小范围的尝试工作 然后再慢慢放量 直到这个全新的功能覆盖到所有的系统用户 也就是说在新功能上线的黑白之间有一个灰 所以这种方法也通常被称为灰度测试 AB 测试 就是指把少部分用户分成平均的两组 其中一组用户体验网站改版的 A 版本 另外一组用户体验网站改版的 B 版本 分别记录清楚相关的所有用户操作数据以后再进行精确的比对 最后分析得出哪一个版本是用户最喜爱的

    2026年3月17日
    3
  • 怎么在mac上录屏_录屏工具

    怎么在mac上录屏_录屏工具您可以为整个屏幕或屏幕上的选定部分录制视频。1、使用“截屏”工具栏要查看“截屏”工具栏,请同时按下以下三个按键:Shift、Command和5。您将看到用于录制整个屏幕、录制屏幕的选定部分或拍摄屏幕静态图像的屏幕控制项:录制整个屏幕点按屏幕控制项中的。指针会变为相机。 点按任意屏幕以开始录制屏幕,或点按屏幕控制项中的“录制”。 要停止录制,请点按菜单栏中的。或者,按下Command-Control-Esc(Escape)。 使用缩略图进行修剪、共享、存储或其他操作…

    2026年3月5日
    4
  • 图像处理——分水岭算法

    图像处理——分水岭算法首先感谢以下两位的博文帮助我的理解:(1)迈克老狼2012  https://www.cnblogs.com/mikewolf2002/p/3304118.html(2)-牧野-       http://blog.csdn.net/dcrmg/article/details/52498440分水岭算法是一种图像区域分割法,在分割的过程中

    2022年5月16日
    65
  • Pycharm设置断点时不显示解决方法

    Pycharm设置断点时不显示解决方法Pycharm 设置断点时不显示解决方法

    2026年3月17日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号