Leetcode 15.三数之和

解法:两处去重+二分法

python 复制代码
class Solution:
    def threeSum(self, nums: List[int]) -> List[List[int]]:
        nums.sort()
        res = []
        visited_numi = [] # 第一处去重
        for i in range(len(nums) - 2):
            if nums[i] not in visited_numi:
                visited_numi.append(nums[i])
                sortnums = nums[i+1: ]
                l, r = 0, len(sortnums) - 1
                while r > l:
                    if sortnums[l] + sortnums[r] == - nums[i]: 
                        res.append([nums[i], sortnums[l], sortnums[r]])
                        while l < r and sortnums[l + 1] == sortnums[l]: l += 1 # 第二处去重
                        while l < r and sortnums[r - 1] == sortnums[r]: r -= 1
                        l += 1
                        r -= 1
                    elif sortnums[l] + sortnums[r] > - nums[i]: r -= 1
                    else: l += 1
        return res
相关推荐
spcier21 小时前
图论拓扑排序-Kahn 算法
算法·图论
知星小度S21 小时前
动态规划(一)——思想入门
算法·动态规划
ysa05103021 小时前
动态规划-逆向
c++·笔记·算法
燃于AC之乐1 天前
我的算法修炼之路--7—— 手撕多重背包、贪心+差分,DFS,从数学建模到路径DP
c++·算法·数学建模·深度优先·动态规划(多重背包)·贪心 + 差分
chinesegf1 天前
文本嵌入模型的比较(一)
人工智能·算法·机器学习
We་ct1 天前
LeetCode 6. Z 字形变换:两种解法深度解析与优化
前端·算法·leetcode·typescript
REDcker1 天前
Redis容灾策略与哈希槽算法详解
redis·算法·哈希算法
福楠1 天前
C++ STL | map、multimap
c语言·开发语言·数据结构·c++·算法
Sarvartha1 天前
二分查找学习笔记
数据结构·c++·算法
难得的我们1 天前
C++与区块链智能合约
开发语言·c++·算法