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

你可能感兴趣的文章
node.js模块、包
查看>>
node.js的express框架用法(一)
查看>>
Node.js的交互式解释器(REPL)
查看>>
Node.js的循环与异步问题
查看>>
Node.js高级编程:用Javascript构建可伸缩应用(1)1.1 介绍和安装-安装Node
查看>>
nodejs + socket.io 同时使用http 和 https
查看>>
NodeJS @kubernetes/client-node连接到kubernetes集群的方法
查看>>
NodeJS API简介
查看>>
Nodejs express 获取url参数,post参数的三种方式
查看>>
nodejs http小爬虫
查看>>
nodejs libararies
查看>>
nodejs npm常用命令
查看>>
nodejs npm常用命令
查看>>
Nodejs process.nextTick() 使用详解
查看>>
NodeJS yarn 或 npm如何切换淘宝或国外镜像源
查看>>
nodejs 中间件理解
查看>>
nodejs 创建HTTP服务器详解
查看>>
nodejs 发起 GET 请求示例和 POST 请求示例
查看>>
NodeJS 导入导出模块的方法( 代码演示 )
查看>>
nodejs 开发websocket 笔记
查看>>