博客
关于我
刷题 --三数之和
阅读量: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/

你可能感兴趣的文章
MQTT 保留消息
查看>>
MQTT 持久会话与 Clean Session 详解
查看>>
MQTT工作笔记0007---剩余长度
查看>>
MQTT工作笔记0009---订阅主题和订阅确认
查看>>
Mqtt搭建代理服务器进行通信-浅析
查看>>
MS Edge浏览器“STATUS_INVALID_IMAGE_HASH“兼容性问题
查看>>
ms sql server 2008 sp2更新异常
查看>>
MS UC 2013-0-Prepare Tool
查看>>
MSBuild 教程(2)
查看>>
msbuild发布web应用程序
查看>>
MSB与LSB
查看>>
MSCRM调用外部JS文件
查看>>
MSCRM调用外部JS文件
查看>>
MSEdgeDriver (Chromium) 不适用于版本 >= 79.0.313 (Canary)
查看>>
MsEdgeTTS开源项目使用教程
查看>>
msf
查看>>
MSSQL数据库查询优化(一)
查看>>
MSSQL数据库迁移到Oracle(二)
查看>>
MSSQL日期格式转换函数(使用CONVERT)
查看>>
MSTP多生成树协议(第二课)
查看>>