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

day-52 三数之和

在这里插入图片描述
思路
双指针:确定最小的那个数(i0<=i<nums.length-2),剩下两个数可以利用双指针的思想。当最小的那个数大于零时,可以直接返回,因为后面的不可能还有满足题意的组合。

解题过程
为了所有满足题意的组合不重合,每当选定一个元素时,若该元素与排在他之前相邻的那个元素相同,需要直接跳过

Code

class Solution {public List<List<Integer>> threeSum(int[] nums) {Arrays.sort(nums);List<List<Integer>> list=new ArrayList<>();int len=nums.length;for(int i=0;i<len-2;i++){if(nums[i]>0) break;if(i>0&&nums[i]==nums[i-1]) continue;int j=i+1;int k=len-1;while(j<k){if(nums[i]+nums[j]+nums[k]==0){List<Integer> p=new ArrayList<>();p.add(nums[i]);p.add(nums[j]);p.add(nums[k]);list.add(p);j++;while(j<len&&nums[j]==nums[j-1]) j++;}else if(nums[i]+nums[j]+nums[k]<0){j++;while(j<len&&nums[j]==nums[j-1]) j++;}else{k--;while(k>0&&nums[k]==nums[k+1]) k--;}}}return list;}
}作者:菜卷
链接:https://leetcode.cn/problems/3sum/solutions/2912217/san-shu-zhi-he-by-ashi-jian-chong-dan-li-oecj/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

http://www.mrgr.cn/news/23854.html

相关文章:

  • Qt放Element网页滑动菜单栏
  • udp的广播,多播,单播 demo
  • 图书馆上新了!新华书店×度小满推出“开学季悦读计划”公益活动
  • OpenCV findTours函数及其用法
  • Hive SQL子查询应用
  • springboot基础-Druid数据库连接池使用
  • [产品管理-4]:NPDP新产品开发 - 2 - 制定企业经营战略目标的结构化方法与工具
  • [Python]一文掌握Nuitka 参数语法详细介绍与示例
  • 7.科学计算模块Numpy(4)ndarray数组的常用操作(二)
  • WindTerm 2.6.1:全新版本,更强大,更便捷!
  • Web开发:ABP框架2——层次结构、ORM的使用、Webapi控制器的编写
  • 计算机网络:概述 - 计算机网络概述
  • c语言--力扣简单题目(删除排序链表中的重复元素)讲解
  • windows软件应该安装在哪里
  • 园区竞争十分激烈,各类园区网站美出天际啦。
  • 经验笔记:Web 浏览器存储手段
  • 告别繁琐,IsMyHdOK硬盘测速,即刻享受科技便利
  • 内网安全:反弹shell
  • 力扣题/回溯/单词搜索
  • vue2项目如何设置同样的接口第一次请求有效,如果第二次请求同样的接口,则不去请求,因为第一次请求还没有返回数据