news 2026/2/25 1:38:46

⭐力扣刷题:三数之和

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
⭐力扣刷题:三数之和

题目:
给你一个整数数组 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] 。
注意,输出的顺序和三元组的顺序并不重要。

示例 2:

输入:nums = [0,1,1]
输出:[]
解释:唯一可能的三元组和不为 0 。

示例 3:

输入:nums = [0,0,0]
输出:[[0,0,0]]
解释:唯一可能的三元组和为 0 。

解析:
这道题使用双指针法会非常的方便,首先要将数组进行排序,随后开启for循环,i从0的位置开始,设置左指针指向i+1,设置右指针指向数组最后一个元素,然后计算a+b+c的值,如果这三个和的值小于0,那么左指针往右移动,如果三个数之和大于0,右指针往左移动
但是我们需要注意两个点,一个是i要保证得到去重,另外一个就是左指针和右指针指向的元素也是需要去重的

具体代码:

/** * @param {number[]} nums * @return {number[][]} */varthreeSum=function(nums){constres=[]constlen=nums.length nums.sort((a,b)=>a-b)for(leti=0;i<len;i++){letl=i+1letr=len-1iNum=nums[i]if(iNum>0)returnresif(iNum===nums[i-1])continuewhile(l<r){letlNum=nums[l]letrNum=nums[r]letsum=iNum+lNum+rNumif(sum<0)l++elseif(sum>0)r--else{res.push([iNum,lNum,rNum])while(l<r&&nums[l]===nums[l+1]){l++}while(l<r&&nums[r]===nums[r-1]){r--}l++r--}}}returnres};
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/24 20:41:21

论面向服务的体系结构在系统集成中的应用

在数字化转型加速推进的当下&#xff0c;企业对办公自动化&#xff08;OA&#xff09;系统的集成性、扩展性和灵活性提出了更高要求。面向服务的体系结构&#xff08;SOA&#xff09;以其松耦合、服务复用、跨平台交互等核心特性&#xff0c;成为破解OA系统集成难题的关键技术架…

作者头像 李华
网站建设 2026/2/16 19:44:43

Dify重排序核心技术解析(20年经验总结的3大选型原则)

第一章&#xff1a;检索结果重排序的 Dify 算法选择在构建高效的检索增强生成&#xff08;RAG&#xff09;系统时&#xff0c;检索结果的排序质量直接影响最终回答的准确性。Dify 作为一款低代码 AI 应用开发平台&#xff0c;支持多种重排序&#xff08;Re-ranking&#xff09;…

作者头像 李华
网站建设 2026/2/24 4:37:44

Python 面试 30 道必刷题(含标准答案)

覆盖 基础 进阶 高级 实战&#xff0c;按面试出现频率排序&#xff0c;可以直接背 理解。一、基础必刷&#xff08;1–10&#xff09;1️⃣ Python 是解释型还是编译型&#xff1f;答&#xff1a;表面是解释型实际流程&#xff1a;py → 字节码(.pyc) → PVM 执行2️⃣ is …

作者头像 李华
网站建设 2026/2/15 20:06:09

Dify导出格式怎么选?一文搞懂JSON、CSV、XML适用场景

第一章&#xff1a;Dify导出格式的核心概念Dify作为一个面向AI应用开发的低代码平台&#xff0c;其导出格式设计旨在实现工作流、提示词模板与模型配置的可移植性。理解导出格式的结构是实现跨环境迁移和版本管理的关键。导出内容的组成结构 Dify导出的数据通常以JSON格式封装&…

作者头像 李华
网站建设 2026/2/22 12:51:44

Dify索引设计陷阱,90%工程师都忽略的3个关键点

第一章&#xff1a;视频帧检索的 Dify 索引优化在大规模视频数据处理场景中&#xff0c;高效检索关键帧是实现智能分析的核心环节。Dify 框架通过构建语义索引结构&#xff0c;显著提升了视频帧的查询效率与准确率。其核心机制在于将视觉特征向量化&#xff0c;并结合近似最近邻…

作者头像 李华
网站建设 2026/2/24 19:02:07

Dify日志分析进阶指南:重构重排序流程的4个核心洞察

第一章&#xff1a;检索重排序的 Dify 日志分析在构建基于大语言模型的应用时&#xff0c;Dify 作为低代码开发平台&#xff0c;提供了完整的日志追踪机制&#xff0c;尤其在检索增强生成&#xff08;RAG&#xff09;流程中&#xff0c;检索重排序环节的日志对性能调优至关重要…

作者头像 李华