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

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

三数之和问题可以通过两指针法高效解决,以下是详细的解决方案:

方法思路

给定一个已经排好序的数组,找出所有满足三个数之和为零的三元组。我们可以使用两指针法来解决这个问题,具体步骤如下:

  • 检查数组长度:如果数组长度小于3,显然无法形成三元组,直接返回空列表。
  • 遍历数组:从数组开始遍历,找到第一个可能为正数的元素作为起始点。
  • 初始化指针:设置left指针为当前元素的下一个位置,right指针为数组末尾。
  • 处理重复元素:如果当前元素与前一个元素相同,跳过。
  • 使用两个指针:left从左侧开始,right从右侧开始,逐步调整指针位置,直到left超过right。
  • 计算和并记录结果:计算当前元素与left、right的和,如果和为零,记录结果,并处理重复元素。
  • 调整指针位置:根据和的值调整指针位置:和小于零时,left++;和大于零时,right--。
  • 返回结果:最终返回所有找到的三元组列表。
  • 代码实现

    import java.util.ArrayList;import java.util.List;public class Solution {    public List
    > threeSum(int[] nums) { List
    > listAll = new ArrayList<>(); if (nums.length < 3) { return listAll; } int len = nums.length; for (int i = 0; i < len; i++) { if (nums[i] > 0) { break; } List
    list = new ArrayList<>(); 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.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--; } } else if (sum < 0) { left++; } else { right--; } } } return listAll; }}

    代码解释

  • 初始化变量:创建一个空列表listAll来存储结果,检查数组长度是否小于3,若是则返回空列表。
  • 遍历数组:从数组开始遍历,找到第一个可能为正数的元素作为起始点。
  • 设置指针:left指针从当前元素的下一个位置开始,right指针设置为数组末尾。
  • 处理重复元素:检查当前元素是否与前一个元素相同,如果相同则跳过,避免重复处理。
  • 两指针循环:使用while循环控制left和right的位置,直到left超过right。
  • 计算和:计算当前元素与left、right的和,如果和为零,记录结果,并处理重复元素。
  • 调整指针:根据和的值调整指针位置:和小于零时,left++;和大于零时,right--。
  • 返回结果:将所有找到的三元组列表返回。
  • 这种方法的时间复杂度为O(n),空间复杂度为O(1),能够高效解决问题。

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

    你可能感兴趣的文章
    Openlayers中使用Cluster实现缩放地图时图层聚合与取消聚合
    查看>>
    Openlayers中使用Image的rotation实现车辆定位导航带转角(判断车辆图片旋转角度)
    查看>>
    Openlayers中使用Overlay实现点击要素弹窗并且弹窗随之移动
    查看>>
    Vmware系列&虚拟机系列【仅供参考】:使用vCenter Auto Deploy制作ESXI系统封装(适合高版本vSphere)
    查看>>
    Openlayers中加载GeoJson文件显示地图
    查看>>
    Openlayers中加载Geoserver切割的EPSG:900913离线瓦片图层组
    查看>>
    Openlayers中加载Geoserver切割的EPSG:900913离线瓦片地图并显示
    查看>>
    Openlayers中多图层遮挡时调整图层上下顺序
    查看>>
    Openlayers中实现地图上添加一条红色直线
    查看>>
    Openlayers中将某个feature置于最上层
    查看>>
    Openlayers中点击地图获取坐标并输出
    查看>>
    Openlayers中设置定时绘制和清理直线图层
    查看>>
    Openlayers入门教程 --- 万字长篇
    查看>>
    Openlayers图文版实战,vue项目从0到1做基础配置
    查看>>
    OpenLayers学习三:地图旋转及地图跳转到某一点的方式(以类为接口)
    查看>>
    Openlayers实战:loadstart和loadend事件
    查看>>
    Openlayers实战:modifystart、modifyend互动示例
    查看>>
    Openlayers实战:判断共享单车是否在电子围栏内
    查看>>
    Openlayers实战:加载Bing地图
    查看>>
    Openlayers实战:加载GeoJSON
    查看>>