博客
关于我
刷题 --三数之和
阅读量: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优化之BTree索引使用规则
查看>>
MySQL优化之推荐使用规范
查看>>
Webpack Critical CSS 提取与内联教程
查看>>
mysql优化概述(范式.索引.定位慢查询)
查看>>
MySQL优化的一些需要注意的地方
查看>>
mysql优化相关
查看>>
MySql优化系列-优化版造数据(存储过程+函数+修改存储引擎)-2
查看>>
MySql优化系列-进阶版造数据(load data statment)-3
查看>>
MySql优化系列-造数据(存储过程+函数)-1
查看>>
MySQL优化配置详解
查看>>
Mysql优化高级篇(全)
查看>>
mysql会员求积分_MySql-统计所有会员的最高前10次的积分和
查看>>
mysql会对联合索性排序优化_MySQL索引优化实战
查看>>
MySQL作为服务端的配置过程与实际案例
查看>>