【 每天学习一点算法 2026/01/30】三数之和

每天学习一点算法 2026/01/30

题目:三数之和

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

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

这道题可以变成再数字中找两数和为某一个数,我们遍历数组将然后在其余项中找与这个项和为 0 的两项即可,为了方便后续的选择操作,我们可以对数组进行排序,再利用双指针找到目标值(注意事项我就写在代码备注里面了)。

typescript 复制代码
function threeSum(nums: number[]): number[][] {
  nums.sort((a, b) => a - b) // 对数组进行排序
  const res = []
  for (let i = 0; i < nums.length - 2; i++) {
    if (i > 0 && nums[i] === nums[i - 1]) continue // 跳过重复的项
    if (nums[i] > 0) break; // 因为已经进行了排序,如果当前值已经大于 0 就不可能和为 0 了
    let left = i + 1 // 左指针
    let right = nums.length - 1 // 右指针
    const traget = -nums[i] // 目标值
    while (left < right) {
      const sum = nums[left] + nums[right]
      // 两数和与目标值不相等根据情况移动指针
      if (sum > traget) {
        right--
      } else if (sum < traget) {
        left++
      } else {
        // 两数和与目标值相等
        res.push([nums[i], nums[left], nums[right]]) // 添加三元组至结果数组中
        // 跳过重复项
        while (left < right && nums[left] === nums[left + 1]) left++ 
        while (left < right && nums[right] === nums[right - 1]) right--
        // 移动指针
        left++
        right--
      }
    }
  }
  return res
};

题目来源:力扣(LeetCode)

相关推荐
小超超爱学习993714 分钟前
大数乘法,超级简单模板
开发语言·c++·算法
Ricardo-Yang28 分钟前
SCNP语义分割边缘logits策略
数据结构·人工智能·python·深度学习·算法
凌波粒29 分钟前
LeetCode--344.反转字符串(字符串/双指针法)
算法·leetcode·职场和发展
啊哦呃咦唔鱼37 分钟前
LeetCode hot100-543 二叉树的直径
算法·leetcode·职场和发展
知识分享小能手1 小时前
MongoDB入门学习教程,从入门到精通,MongoDB的选择片键 - 完整知识点(16)
数据库·学习·mongodb
知识分享小能手1 小时前
MongoDB入门学习教程,从入门到精通,MongoDB分片配置完全指南(15)
数据库·学习·mongodb
soragui1 小时前
【Python】第 4 章:Python 数据结构实现
数据结构·windows·python
sinat_286945191 小时前
harness engineering
人工智能·算法·chatgpt
Dyanic1 小时前
AMSFusion:一种基于注意力机制的自适应多尺度红外与可见光图像融合网络
图像处理·人工智能·学习
少许极端1 小时前
算法奇妙屋(四十三)-贪心算法学习之路10
学习·算法·贪心算法