求解三数之和

问题描述

给你一个整数数组 nums ,判断是否存在三元组 [nums[i], nums[j], nums[k]] 满足 i != j、i != 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] 。

注意,输出的顺序和三元组的顺序并不重要。

解答

这个问题是经典的"三数之和"问题,可以使用双指针法来解决。以下是具体的步骤:

首先,需要对数组进行排序,以便于后续的操作。

然后,遍历数组中的每个元素,作为三元组的第一个元素。

对于每个元素,使用两个指针(一个从当前元素的下一个元素开始,一个从数组的末尾开始)来寻找另外两个元素,使得三元组的和为 0。

如果找到满足条件的三元组,则将其添加到结果中。

最后,返回所有满足条件的三元组。

以下是具体的代码实现:

python 复制代码
def threeSum(nums):
    # 排序数组
    nums.sort()
    result = []
    
    for i in range(len(nums) - 2):
        # 跳过重复的元素
        if i > 0 and nums[i] == nums[i - 1]:
            continue
        
        left, right = i + 1, len(nums) - 1
        while left < right:
            total = nums[i] + nums[left] + nums[right]
            
            if total < 0:
                left += 1
            elif total > 0:
                right -= 1
            else:
                result.append([nums[i], nums[left], nums[right]])
                # 跳过重复的元素
                while left < right and nums[left] == nums[left + 1]:
                    left += 1
                while left < right and nums[right] == nums[right - 1]:
                    right -= 1
                left += 1
                right -= 1
    
    return result

# 测试
nums = [-10, 0, 10, 20, -10, -40]
print(threeSum(nums))

这个代码实现使用了双指针法来寻找满足条件的三元组,并且使用了排序和去重来确保结果的正确性和唯一性。

相关推荐
做cv的小昊9 分钟前
【TJU】研究生应用统计学课程笔记(8)——第四章 线性模型(4.1 一元线性回归分析)
笔记·线性代数·算法·数学建模·回归·线性回归·概率论
贾斯汀玛尔斯39 分钟前
每天学一个算法--倒排索引(Inverted Index)
算法·inverted-index
小e说说43 分钟前
打破偏科困境:这些学习软件助孩子重燃学习热情
算法
月昤昽1 小时前
autoCAD二次开发 4.正多边形与collection区分
算法·c#·二次开发·autocad二次开发
休息一下接着来2 小时前
C++ 固定容量环形队列实现
c++·算法
im_AMBER2 小时前
手撕hot100之矩阵!看完这篇就AC~
javascript·数据结构·线性代数·算法·leetcode·矩阵
笨笨饿2 小时前
#79_NOP()嵌入式C语言中内联汇编宏的抽象封装模式研究
linux·c语言·网络·驱动开发·算法·硬件工程·个人开发
如君愿2 小时前
考研复习 Day 30 | 习题--计算机网络 第五章(运输层 上)、数据结构 图(上)
数据结构·计算机网络·课后习题
weixin_421725263 小时前
C语言中volatile关键字怎么用C语言volatile在多线程中的作用
c语言·数据结构·运算符优先级·变量命名·volatile关键字
风萧萧19993 小时前
问答样例如何在RAG问答中使用?
算法