资讯专栏INFORMATION COLUMN

【Leetcode刷题】15. 三数之和

bergwhite / 1638人阅读

摘要:题目给你一个包含个整数的数组,判断中是否存在三个元素,,,使得请你找出所有和为且不重复的三元组。

题目

给你一个包含 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]输出:[]

提示

(1)0 <= nums.length <= 3000

(2)-105 <= nums[i] <= 105

解题思路

(1)对输入的nums中遍历获取第一个数,相同时跳过

(2)在第一个数右边遍历获取第二个数,相同时跳过

(3)在右边开始往回找第三个数,但是要保证第三个数在第二个数右边

(4)如果找到三个数加起来的和为0,则记录进ans

(5)最后输出ans

代码

class Solution:    def threeSum(self, nums: List[int]) -> List[List[int]]:        n = len(nums)        nums.sort()        ans = list()                # 枚举 a        for first in range(n):            # 需要和上一次枚举的数不相同            if first > 0 and nums[first] == nums[first - 1]:                continue            # c 对应的指针初始指向数组的最右端            third = n - 1            target = -nums[first]            # 枚举 b            for second in range(first + 1, n):                # 需要和上一次枚举的数不相同                if second > first + 1 and nums[second] == nums[second - 1]:                    continue                # 需要保证 b 的指针在 c 的指针的左侧                while second < third and nums[second] + nums[third] > target:                    third -= 1                # 如果指针重合,随着 b 后续的增加                # 就不会有满足 a+b+c=0 并且 b

Reference

题库 - 力扣 (LeetCode) 全球极客挚爱的技术成长平台

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/119999.html

相关文章

  • LeetCode15.三数之和 JavaScript

    摘要:三数之和给定一个包含个整数的数组,判断中是否存在三个元素,,,使得找出所有满足条件且不重复的三元组。例如给定数组,满足要求的三元组集合为答案参考 LeetCode15.三数之和 JavaScript 给定一个包含 n 个整数的数组 nums,判断 nums 中是否存在三个元素 a,b,c ,使得 a + b + c = 0 ?找出所有满足条件且不重复的三元组。 注意:答案中不可以包含重...

    idisfkj 评论0 收藏0
  • LeetCode 攻略 - 2019 年 8 月上半月汇总(109 题攻略)

    摘要:每天会折腾一道及以上题目,并将其解题思路记录成文章,发布到和微信公众号上。三汇总返回目录在月日月日这半个月中,做了汇总了数组知识点。或者拉到本文最下面,添加的微信等会根据题解以及留言内容,进行补充,并添加上提供题解的小伙伴的昵称和地址。 LeetCode 汇总 - 2019/08/15 Create by jsliang on 2019-08-12 19:39:34 Recently...

    tracy 评论0 收藏0
  • python LeetCode 15.三数之和

    摘要:给定一个包含个整数的数组,判断中是否存在三个元素,,,使得找出所有满足条件且不重复的三元组。 给定一个包含 n 个整数的数组 nums,判断 nums 中是否存在三个元素 a,b,c ,使得 a + b + c = 0 ?找出所有满足条件且不重复的三元组。 注意:答案中不可以包含重复的三元组。 例如, 给定数组 nums = [-1, 0, 1, 2, -1, -4], 满足要求的三元...

    stonezhu 评论0 收藏0
  • LeetCode16.最接近的三数之和 JavaScript

    摘要:最接近的三数之和给定一个包括个整数的数组和一个目标值。返回这三个数的和。假定每组输入只存在唯一答案。例如,给定数组,,,和与最接近的三个数的和为答案参考和三数之和一样,我先用的循环,现在用的循环 LeetCode16.最接近的三数之和 JavaScript 给定一个包括 n 个整数的数组 nums 和 一个目标值 target。找出 nums 中的三个整数,使得它们的和与 target...

    xiaokai 评论0 收藏0

发表评论

0条评论

bergwhite

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<