博客
关于我
刷题 --三数之和
阅读量:329 次
发布时间:2019-03-04

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

在这里插入图片描述

思路如下:
遍历一遍数组
其中过程设立左右两个指针进行判断遍历
我们设置 left为做指针 right为右指针
因为已经有序了 当nums[i]为正数的时候就不可能 在以后的数字中找到和为0
nums[i]+nums[left]+nums[right] =0 添加结果 <0说明左边太小 left++ >0说明右边太大 right–
注意为零后我们仍然不能就此退出当前,有可能下面还有使结果为零的组合
所以任然要继续left和right指针移动 但是当有重复的要掠过
因为
if(i>0 && nums[i]==nums[i-1]) continue;
判断nums[i]是否重复 开头是否重复
while(left < right && nums[left+1] == nums[left]) ++left;
while (left < right && nums[right-1] == nums[right]) --right;
判断中间和右边是否重复

class Solution {       public List
> threeSum(int[] nums) { List
> listAll = new ArrayList
>(); Arrays.sort(nums); /* 思路如下: 遍历一遍数组 其中过程设立左右两个指针进行判断遍历 我们设置 left为做指针 right为右指针 因为已经有序了 当nums[i]为正数的时候就不可能 在以后的数字中找到和为0 nums[i]+nums[left]+nums[right] =0 添加结果 <0说明左边太小 left++ >0说明右边太大 right-- */ if(nums.length<3) return listAll; int len = nums.length; for( int i = 0; i < len ; i++){ if(nums[i] > 0) break; int left = i+1; int right =len-1; if(i>0 && nums[i]==nums[i-1]) continue; while(left < right){ int sum = nums[i]+nums[left]+nums[right]; if(sum == 0){ List
list = new ArrayList<>(); list.add(nums[i]); list.add(nums[left]); list.add(nums[right]); listAll.add(list); //接下来要判断下一个 元素是不是和当前元素相等,如果相等掠过 while(left < right && nums[left+1] == nums[left]) ++left; while (left < right && nums[right-1] == nums[right]) --right; //执行完要向前签进 之前就忘了这个 为零时的后面要++ ++left; --right; } if(sum < 0 ) left++; if(sum>0) right--; } } return listAll; }}

在这里插入图片描述

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

你可能感兴趣的文章
mysql事务理解
查看>>
MySQL事务详解结合MVCC机制的理解
查看>>
MySQL事务隔离级别:读未提交、读已提交、可重复读和串行
查看>>
MySQL事务隔离级别:读未提交、读已提交、可重复读和串行
查看>>
webpack css文件处理
查看>>
mysql二进制包安装和遇到的问题
查看>>
MySql二进制日志的应用及恢復
查看>>
mysql互换表中两列数据方法
查看>>
mysql五补充部分:SQL逻辑查询语句执行顺序
查看>>
mysql交互式连接&非交互式连接
查看>>
MySQL什么情况下会导致索引失效
查看>>
Mysql什么时候建索引
查看>>
MySql从入门到精通
查看>>
MYSQL从入门到精通(一)
查看>>
MYSQL从入门到精通(二)
查看>>
mysql以下日期函数正确的_mysql 日期函数
查看>>
mysql以服务方式运行
查看>>
mysql优化--索引原理
查看>>
MySQL优化之BTree索引使用规则
查看>>
MySQL优化之推荐使用规范
查看>>