LeetCode热题100-三数之和

关键在去重,而且题目要求返回三个值,所以使用排序 + 双指针

记住这里不要求返回具体值索引,所以排序直接使用nums.sore()即可,节约空间;若需要保留原列表可以使用new_nums = sorted(nums).

python 复制代码
class Solution:
    def threeSum(self, nums: list[int]) -> list[list[int]]:
        if not nums:
            return []
        nums.sort()
        length = len(nums)
        res = []

        for i in range(length):
            
            # 首位去重
            if i > 0 and nums[i] == nums[i-1]:
                continue
            left = i + 1
            right = length -1

            while left < right:
                sum = nums[i] + nums[left] + nums[right]
                if sum == 0:
                    res.append([nums[i], nums[left], nums[right]])

                    # left标志位去重
                    while left < right and nums[left] == nums[left + 1]:
                        left += 1

                    # right 标志位去重
                    while left < right and nums[right] == nums[right -1]:
                        right -= 1

                    left += 1
                    right -= 1

                elif sum < 0:
                    left += 1
                else:
                    right -= 1
        
        return res
相关推荐
计算机安禾几秒前
【数据库系统原理】第14篇:关系模式的语义约束:函数依赖的公理系统与闭包计算
人工智能·算法·机器学习
量化君也2 分钟前
快速入门量化交易都要学些什么?
大数据·人工智能·python·算法·金融
AbandonForce12 分钟前
滑动窗口:定长滑动窗口与不定长滑动窗口
数据结构·c++·算法
炸薯条!25 分钟前
二叉树的链式表示(2)
java·数据结构·算法
Tairitsu_H28 分钟前
[LC优选算法#2] 滑动窗口 | 长度最小的子数组 | 无重复字符的最长子串 | 最大连续1的个数
算法
小欣加油30 分钟前
leetcode3689最大子数组总值I
c++·算法·leetcode·职场和发展·贪心算法
下午写HelloWorld37 分钟前
【概念与应用】轻量级加密算法LEA、动态脱敏算法DDA、零知识证明ZKP和优化协同交互协议OCIP
算法·区块链·密码学·安全架构·零知识证明
飞舞哲1 小时前
三维点云最小二乘拟合MATLAB程序
开发语言·算法·matlab
Coder-magician1 小时前
《代码随想录》刷题打卡day12:二叉树part02
数据结构·c++·算法
海梨花1 小时前
字节面试高频算法题
java·算法·面试·职场和发展