当前位置: 首页 > ds >正文

力扣-三数之和

1.题目描述

2.题目链接

LCR 007. 三数之和 - 力扣(LeetCode) 

3.题目代码

import java.util.*;
class Solution {public List<List<Integer>> threeSum(int[] nums) {Arrays.sort(nums);int temp=nums.length-1;Set<List<Integer>> set=new HashSet<>();while(temp>1){int left=0,right=temp-1;while(left<right){if(nums[left]+nums[right]+nums[temp]==0){List<Integer> row=Arrays.asList(nums[left],nums[right],nums[temp]);set.add(row);left++;right--;}else if(nums[left]+nums[right]+nums[temp]>0){right--;}else{left++;}}temp--;}return new ArrayList<>(set);}
}

4.解题思路

这道题我们用的依然还是双指针+定数指针的解题思路,和前面我记录的有效三角形的个数的OJ题目一样,只需要定义定数指针在数组的最后一个元素上,再在剩余数组的边界定义两个指针,根据单调性来进行指针的移动即可。

5.代码细节

1)类型转换

因为我们为了方便去重,定义的是set,而题目中的泛型要求我们返回List<List<Integer>>,所以我们在定义完set之后:

 Set<List<Integer>> set = new HashSet<>();

还需要在最后转换类型:

 return new ArrayList<>(set);

2)构造动态三元组

创建动态列表存储三元组:

List<Integer> row=Arrays.asList(nums[left],nums[right],nums[temp]);

3)找到三元组后的指针移动逻辑

在找到1个三元组并且存入set后,我们需要移动双指针:left--,right++

为什么呢?

因为我们需要寻找下一个符合条件的三元组,也就是寻找下一个满足nums[left]+nums[right]+nums[temp]==0的三元组,但是如果移动单个指针等式的平衡会被打破左边一定不会等于右边只有同时移动双指针,才有可能重新满足不等式。

http://www.xdnf.cn/news/8013.html

相关文章:

  • 融云 uni-app IMKit 上线,1 天集成,多端畅行
  • 在 Excel xll 自动注册操作 中使用东方仙盟软件2————仙盟创梦IDE
  • 时钟树:概念与编程详解 (铁头山羊)
  • 人工智能小白转型学习指南
  • 对单调栈的理解
  • Spring IOCDI————(2)
  • Linux | tmux | 无法复制粘贴
  • C++类和对象(2)
  • PyTorch学习之:torch.gather是什么?
  • 海康NVR录像回放SDK原始流转FLV视频流:基于Java的流媒体转码(无需安装第三方插件ffmpeg)
  • 远程访问家里的路由器:异地访问内网设备或指定端口网址
  • 芯片分享之X5045PI性能介绍
  • Backbone
  • Typescript 教程
  • Baklib智启企业AI知识管理
  • MySQL 主从复制搭建全流程:基于 Docker 与 Harbor 仓库
  • 杂记10---ldd获取依赖so名称并导出txt文件
  • 数字电子技术基础(六十二)——使用Multisim软件绘制边沿触发的D触发器和JK触发器
  • 2025年 PMP 6月 8月 专题知识
  • Python数据分析基础
  • LangChain入门和应用#1
  • 工商总局可视化模版-Echarts的纯HTML源码
  • CMake跨平台编译生成:从理论到实战
  • 现代计算机图形学Games101入门笔记(二十一)
  • 【Linux安装与维护】
  • 深入理解C#实例构造函数:对象初始化的关键
  • 动态规划3、悟到核心
  • 【DB2】SQL1639N 处理
  • 建立java项目
  • 免费iOS签名的能使用吗?