博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
leetcode15 3Sum 从数组中找到三个整数,它们的和为0
阅读量:6200 次
发布时间:2019-06-21

本文共 1508 字,大约阅读时间需要 5 分钟。

题目要求

Given an array S of n integers, are there elements a, b, c in S such that a + b + c = 0? Find all unique triplets in the array which gives the sum of zero.Note: The solution set must not contain duplicate triplets.For example, given array S = [-1, 0, 1, 2, -1, -4],A solution set is:[  [-1, 0, 1],  [-1, -1, 2]]

输入一个整数数组,从中找到所有的三个整数组成一个数组,这三个整数的和为0。要求不包括重复的结果

思路一:无hashset or hashmap

这里使用了三个指针。

先对数组进行排序。确定左侧固定的指针,然后移动右侧两个直至找到三个值和为0.如果当前三个指针的值小于0,则将中间的指针右移至下一个不同的值,如果小于0,则将最右侧指针左移至下一个不重复的值。一旦右侧和中间的指针重合,移动左侧指针至下一个不重复的值,并且初始化中间和右侧的指针

public List
> threeSum2(int[] nums) { List
> result = new ArrayList
>(); int length = nums.length; if(length<3){ return result; } Arrays.sort(nums); int i = 0; while(i
0) break; int j = i+1; int k = nums.length - 1; while(j
=0){ //消去右侧重复的数字 while(nums[k--] == nums[k] && j < k); } //消去和当前左指针相同的数字 while(nums[i] == nums[++i] && i < nums.length - 2); } } return result; }

思路二:有hashmap/hashset

利用hashmap/hashset是为了避开重复的值,但是效率值明显不如上一种方法高

public List
> threeSum(int[] num) { Arrays.sort(num); List
> list = new ArrayList
>(); HashSet
> set = new HashSet
>(); for(int i=0;i
l= new ArrayList
(); l.add(num[i]); l.add(num[j]); l.add(num[k]); if(set.add(l)) list.add(l); j++; k--; } else if(num[i]+num[j]+num[k]<0) j++; else k--; } } return list;}

clipboard.png

想要了解更多开发技术,面试教程以及互联网公司内推,欢迎关注我的微信公众号!将会不定期的发放福利哦~

转载地址:http://gjnca.baihongyu.com/

你可能感兴趣的文章
Android开发者指南(10) —— Android API Levels
查看>>
【原创】调用 proc_lib:spawn/1 和 erlang:spawn/1 有什么区别
查看>>
java 获取键盘输入
查看>>
python 守护进程 daemon
查看>>
Java千百问_04异常处理(005)_如何自定义异常
查看>>
adrci命令
查看>>
【转】JavaScript与Java的区别
查看>>
dbms_metadata.get_ddl()来获得对象的定义语句
查看>>
Golang Gob编码
查看>>
Yii 自定义Controller
查看>>
进程间通信之-共享内存Shared Memory--linux内核剖析(十一)
查看>>
利用Eventlog Analyzer分析日志
查看>>
java zip解压缩
查看>>
05. Web大前端时代之:HTML5+CSS3入门系列~H5 多媒体系
查看>>
Java内存查看与分析
查看>>
java.util.Arrays.sort两种方式的排序(及文件读写练习)
查看>>
讨喜的隔离可变性(九)混合使用角色和STM
查看>>
boost date_time
查看>>
R语言数据的输入
查看>>
CSS Reset ,你选对了吗?
查看>>