博客
关于我
刷题 --三数之和
阅读量: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的引擎以及优缺点_MySQL有哪些存储引擎,各自的优缺点,应用场景-阿里云开发者社区...
查看>>
MySQL的操作:
查看>>
mysql的数据类型有哪些?
查看>>
mysql的语法规范
查看>>
MySql的连接查询
查看>>
mysql的配置文件参数
查看>>
MySQL的错误:No query specified
查看>>
mysql监控工具-PMM,让你更上一层楼(上)
查看>>
mysql监控工具-PMM,让你更上一层楼(下)
查看>>
MySQL相关命令
查看>>
mysql社工库搭建教程_社工库的搭建思路与代码实现
查看>>
Warning: Can't perform a React state update on an unmounted component. This is a no-
查看>>
mysql笔记 (早前的,很乱)
查看>>
MySQL笔记:InnoDB的锁机制
查看>>
mysql第一天~mysql基础【主要是DDL、DML、DQL语句,以及重点掌握存存引擎、查询(模糊查询)】
查看>>
mysql第二天~mysql基础【查询排序、分页查询、多表查询、数据备份与恢复等】
查看>>
MySQL简介和安装
查看>>
MySQL简单查询
查看>>
MySQL管理利器 MySQL Utilities 安装
查看>>