【 每天学习一点算法 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)

相关推荐
Prince-Peng4 小时前
技术架构系列 - 详解Redis
数据结构·数据库·redis·分布式·缓存·中间件·架构
lxl13074 小时前
学习C++(5)运算符重载+赋值运算符重载
学习
只是懒得想了4 小时前
C++实现密码破解工具:从MD5暴力破解到现代哈希安全实践
c++·算法·安全·哈希算法
码农水水5 小时前
得物Java面试被问:消息队列的死信队列和重试机制
java·开发语言·jvm·数据结构·机器学习·面试·职场和发展
m0_736919105 小时前
模板编译期图算法
开发语言·c++·算法
dyyx1115 小时前
基于C++的操作系统开发
开发语言·c++·算法
AutumnorLiuu5 小时前
C++并发编程学习(一)——线程基础
开发语言·c++·学习
m0_736919105 小时前
C++安全编程指南
开发语言·c++·算法
CS创新实验室5 小时前
关于 Moltbot 的学习总结笔记
笔记·学习·clawdbot·molbot
蜡笔小马5 小时前
11.空间索引的艺术:Boost.Geometry R树实战解析
算法·r-tree