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

leetCode15三数之和(双指针)

目录

1、题目

2、思路

3、代码

4、总结


1、题目

给你一个由 n 个整数组成的数组 nums ,和一个目标值 target 。请你找出并返回满足下述全部条件且不重复的四元组 [nums[a], nums[b], nums[c], nums[d]] (若两个四元组元素一一对应,则认为两个四元组重复):

  • 0 <= a, b, c, d < n
  • abc 和 d 互不相同
  • nums[a] + nums[b] + nums[c] + nums[d] == target

你可以按 任意顺序 返回答案 。

示例 1:

输入:nums = [1,0,-1,0,-2,2], target = 0
输出:[[-2,-1,1,2],[-2,0,0,2],[-1,0,0,1]]

示例 2:

输入:nums = [2,2,2,2,2], target = 8
输出:[[2,2,2,2]]

2、思路

1、对数组进行正序排序,可以防止结果重复
2、循环遍历数组,退化成求2数之和, 循环指数i,i从0开始,注意:需要判断nums[i-1]==nums[i],避免重复结果
3、使用双指着, 左指针j=i+1,  右指针q=nums.length - 1,(1)如果nums[i]+nums[j]+nums[q]>sum,   右指针左移(2)如果nums[i]+nums[j]+nums[q]==sum,   左指针右移,符合结果的数据(3)如果nums[i]+nums[j]+nums[q]<sum,   左指针右移注意:1、要判断nums[i-1]==nums[i]2、需要判断j,q的边界值,免得越界

3、代码

public static List<List<Integer>> threeSum1(int[] nums) {List<List<Integer>> resultList = new ArrayList<>();if (nums == null || nums.length < 3) {return resultList;}//排序Arrays.sort(nums);for (int i = 0; i < nums.length && nums[i] <= 0; i++) {//判断是否重复if (i >= 1 && nums[i] == nums[i - 1]) {continue;}//2数之和int xx = 0 - nums[i];//左指针int j = i + 1;//右指针int q = nums.length - 1;//双指针while (j < q && q >= 0) {//判断是否重复if (j > i + 1 && nums[j] == nums[j - 1]) {j++;continue;}if (nums[j] + nums[q] == xx) {List<Integer> pathList = new ArrayList<>();pathList.add(nums[i]);pathList.add(nums[j]);pathList.add(nums[q]);resultList.add(pathList);j++;} else {if (nums[j] + nums[q] > xx) {//移动右指针q--;} else {//移动左指针j++;}}}}return resultList;
}

4、总结

1、2数之和,可以直接用这个思路

2、4数之和,可以先简化成求3数之和,思路和这个类似

3、一定要注意先做排序,以及遍历循环,要判断nums[i]==nums[i-1],重复就跳过,免得结果重复

http://www.lryc.cn/news/407713.html

相关文章:

  • 数据挖掘-数据预处理
  • 【调试笔记-20240723-Linux-gitee 仓库同步 github 仓库,并保持所有访问链接调整为指向 gitee 仓库的 URL】
  • 《GPT-4o mini:开启开发与创新的新纪元》
  • 生成树协议配置与分析
  • Golang | Leetcode Golang题解之第287题寻找重复数
  • 【音视频SDL2入门】创建第一个窗口
  • 《置身事内:中国政府与经济发展》生活过得好一点,比大多数宏伟更宏伟
  • MongoDB教程(十八):MongoDB MapReduce
  • HTML前端面试题之<iframe>标签
  • Docker-Compose实现MySQL之主从复制
  • jetson显卡没有加速,而是在用cpu推理?
  • Linux下如何安装配置Fail2ban防护工具
  • js的深浅拷贝
  • 实验八: 彩色图像处理
  • Python酷库之旅-第三方库Pandas(048)
  • springboot爱宠屋宠物商店管理系统-计算机毕业设计源码52726
  • 自训练和增量训练word2vec模型
  • 华三路由器开启web访问
  • C++软件开发值得推荐的十大高效软件分析工具
  • vue2老项目中node-sass更换dart-sass
  • 源/目的检查开启导致虚拟IP背后的LVS无法正常访问
  • 类和对象(四)
  • <PLC><HMI><汇川>在汇川HMI画面中,如何为UI设置全局样式?
  • 在Git项目中添加并应用“.gitignore”文件
  • LeetCode Hot100 搜索二维矩阵
  • iOS中的KVO(Key-Value Observing)详解
  • 算法 —— 暴力枚举
  • 构造+有序集合,CF 1023D - Array Restoration
  • Scrapy 爬取旅游景点相关数据(四)
  • Vue常用指令及其生命周期