求解三数之和

问题描述

给你一个整数数组 nums ,判断是否存在三元组 nums\[i, numsj, numsk] 满足 i != j、i != k 且 j != k ,同时还满足 numsi + numsj + numsk == 0 。请你返回所有和为 0 且不重复的三元组。

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

示例 1:

输入:nums = -1,0,1,2,-1,-4

输出:\[-1,-1,2,-1,0,1]

解释:

nums0 + nums1 + nums2 = (-1) + 0 + 1 = 0 。

nums1 + nums2 + nums4 = 0 + 1 + (-1) = 0 。

nums0 + nums3 + nums4 = (-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))

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

相关推荐
8Qi84 小时前
LeetCode 75:颜色分类(荷兰国旗问题)—— Java 题解 ✅
java·算法·leetcode·指针·排序
888CC++5 小时前
如何在 C 语言中进行程序调试?
前端·javascript·算法
pluviophile_s7 小时前
数据结构:第2讲:线性表
数据结构·笔记
(●—●)橘子……7 小时前
力扣第503场周赛练习理解
python·学习·算法·leetcode·职场和发展·周赛
明志数科8 小时前
4D时序标注技术详解:让机器人理解连续动作的数据基础
java·算法·机器人
KaMeidebaby9 小时前
卡梅德生物技术快报|原核表达系统工艺优化:包涵体重折叠 + 分子筛纯化实现功能 RBD 高效制备,附全参数配置
前端·人工智能·算法·数据挖掘·数据分析
无限码力9 小时前
携程0510笔试真题【单数组交换】
算法·携程笔试·携程笔试真题·携程0510笔试真题
Love_云宝儿10 小时前
WKT数据示例并与GeoJSON数据对比
数据结构·gis
BlockWay10 小时前
WEEX Labs 周度观察:微软-OpenAI 合作调整与AI 多云趋势
大数据·人工智能·算法·安全·microsoft