Leetcode Hot 100刷题记录 -Day5(双指针)

2024-08-30 16:44

本文主要是介绍Leetcode Hot 100刷题记录 -Day5(双指针),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

三数之和

问题描述:

        给你一个整数数组 nums ,判断是否存在三元组 [nums[i], nums[j], nums[k]] 满足 i != ji != k 且 j != k ,同时还满足 nums[i] + nums[j] + nums[k] == 0 。请你返回所有和为 0 且不重复的三元组。

示例 1:

输入:nums = [-1,0,1,2,-1,-4]
输出:[[-1,-1,2],[-1,0,1]]
解释:
nums[0] + nums[1] + nums[2] = (-1) + 0 + 1 = 0 
nums[1] + nums[2] + nums[4] = 0 + 1 + (-1) = 0 
nums[0] + nums[3] + nums[4] = (-1) + 2 + (-1) = 0 
不同的三元组是 [-1,0,1] 和 [-1,-1,2] 
注意,输出的顺序和三元组的顺序并不重要

示例 2:

输入:nums = [0,1,1]
输出:[]
解释:唯一可能的三元组和不为 0 

示例 3:

输入:nums = [0,0,0]
输出:[[0,0,0]]
解释:唯一可能的三元组和为 0 
//hot6:三数之和
public class hot6_threeSum {public List<List<Integer>> threeSum(int[] nums){List<List<Integer>> list = new ArrayList<>();//数组排序Arrays.sort(nums);//k为第一个指针,目的将三数之和转化为两数之和for(int k = 0; k < nums.length-2; k++){if (nums[k]>0){break;}if(k>0 && nums[k]==nums[k-1]) continue;//i和j分别为k的下一个指针和末尾指针int i =k+1;int j = nums.length-1;while (i < j){int sum = nums[k]+nums[i]+nums[j];if(sum < 0){while(i<j && nums[i] == nums[++i]);//&&为短路与,即当前面为false时直接跳出循环,不会再判断后面//nums[i] == nums[++i])的意思为:假设当先的i为1,那么nums[i] = nums[1];然后将i=i+1=2;最后判断nums[1]和nums[2]是否相等,即++i是将i先加1再比较,这是i在后面执行时已经变为2} else if (sum > 0) {while (i<j && nums[j] == nums[--j]);}else {list.add(new ArrayList<Integer>(Arrays.asList(nums[k],nums[i],nums[j])));while(i < j && nums[i] == nums[++i]);while(i < j && nums[j] == nums[--j]);}}}return list;}
}//带有输入输出
//hot6:三数之和
//hot6:三数之和
import java.util.*;public class hot6_threeSum {public List<List<Integer>> threeSum(int[] nums){List<List<Integer>> list = new ArrayList<>();//数组排序Arrays.sort(nums);//k为第一个指针,目的将三数之和转化为两数之和for(int k = 0; k < nums.length-2; k++){if (nums[k]>0){break;}if(k>0 && nums[k]==nums[k-1]) continue;//i和j分别为k的下一个指针和末尾指针int i =k+1;int j = nums.length-1;while (i < j){int sum = nums[k]+nums[i]+nums[j];if(sum < 0){//防止出现重复的三位数while(i<j && nums[i] == nums[++i]);//&&为短路与,即当前面为false时直接跳出循环,不会再判断后面//nums[i] == nums[++i])的意思为:假设当先的i为1,那么nums[i] = nums[1];然后将i=i+1=2;最后判断nums[1]和nums[2]是否相等,即++i是将i先加1再比较,这是i在后面执行时已经变为2} else if (sum > 0) {//防止出现重复的三位数while (i<j && nums[j] == nums[--j]);}else {list.add(new ArrayList<Integer>(Arrays.asList(nums[k],nums[i],nums[j])));//防止出现重复的三位数while(i < j && nums[i] == nums[++i]);while(i < j && nums[j] == nums[--j]);}}}return list;}public static void main(String[] args){hot6_threeSum hot6ThreeSum = new hot6_threeSum();int[] nums = {-2,-2,-2,3,4,-1,0};System.out.println("输入:nums = " + Arrays.toString(nums));List<List<Integer>> result = hot6ThreeSum.threeSum(nums);System.out.println("输出:" + result);}
}

知识点总结:

  • 三数之和转换为两数之和
  • &&(短路逻辑与):若是第一个成立,才判断第二个,若是第一个不成立,直接跳出循环
  • nums[i] == nums[++i])的意思为:假设当先的i为1,那么nums[i] = nums[1];然后将i=i+1=2;最后判断nums[1]和nums[2]是否相等,即++i是将i先加1再比较,这是i在后面执行时已经变为2

这篇关于Leetcode Hot 100刷题记录 -Day5(双指针)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1121369

相关文章

SpringBoot3应用中集成和使用Spring Retry的实践记录

《SpringBoot3应用中集成和使用SpringRetry的实践记录》SpringRetry为SpringBoot3提供重试机制,支持注解和编程式两种方式,可配置重试策略与监听器,适用于临时性故... 目录1. 简介2. 环境准备3. 使用方式3.1 注解方式 基础使用自定义重试策略失败恢复机制注意事项

Python UV安装、升级、卸载详细步骤记录

《PythonUV安装、升级、卸载详细步骤记录》:本文主要介绍PythonUV安装、升级、卸载的详细步骤,uv是Astral推出的下一代Python包与项目管理器,主打单一可执行文件、极致性能... 目录安装检查升级设置自动补全卸载UV 命令总结 官方文档详见:https://docs.astral.sh/

统一返回JsonResult踩坑的记录

《统一返回JsonResult踩坑的记录》:本文主要介绍统一返回JsonResult踩坑的记录,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录统一返回jsonResult踩坑定义了一个统一返回类在使用时,JsonResult没有get/set方法时响应总结统一返回

Go学习记录之runtime包深入解析

《Go学习记录之runtime包深入解析》Go语言runtime包管理运行时环境,涵盖goroutine调度、内存分配、垃圾回收、类型信息等核心功能,:本文主要介绍Go学习记录之runtime包的... 目录前言:一、runtime包内容学习1、作用:① Goroutine和并发控制:② 垃圾回收:③ 栈和

java对接海康摄像头的完整步骤记录

《java对接海康摄像头的完整步骤记录》在Java中调用海康威视摄像头通常需要使用海康威视提供的SDK,下面这篇文章主要给大家介绍了关于java对接海康摄像头的完整步骤,文中通过代码介绍的非常详细,需... 目录一、开发环境准备二、实现Java调用设备接口(一)加载动态链接库(二)结构体、接口重定义1.类型

Java空指针异常NullPointerException的原因与解决方案

《Java空指针异常NullPointerException的原因与解决方案》在Java开发中,NullPointerException(空指针异常)是最常见的运行时异常之一,通常发生在程序尝试访问或... 目录一、空指针异常产生的原因1. 变量未初始化2. 对象引用被显式置为null3. 方法返回null

apache的commons-pool2原理与使用实践记录

《apache的commons-pool2原理与使用实践记录》ApacheCommonsPool2是一个高效的对象池化框架,通过复用昂贵资源(如数据库连接、线程、网络连接)优化系统性能,这篇文章主... 目录一、核心原理与组件二、使用步骤详解(以数据库连接池为例)三、高级配置与优化四、典型应用场景五、注意事

SpringBoot实现文件记录日志及日志文件自动归档和压缩

《SpringBoot实现文件记录日志及日志文件自动归档和压缩》Logback是Java日志框架,通过Logger收集日志并经Appender输出至控制台、文件等,SpringBoot配置logbac... 目录1、什么是Logback2、SpringBoot实现文件记录日志,日志文件自动归档和压缩2.1、

qtcreater配置opencv遇到的坑及实践记录

《qtcreater配置opencv遇到的坑及实践记录》我配置opencv不管是按照网上的教程还是deepseek发现都有些问题,下面是我的配置方法以及实践成功的心得,感兴趣的朋友跟随小编一起看看吧... 目录电脑环境下载环境变量配置qmake加入外部库测试配置我配置opencv不管是按照网上的教程还是de

使用nohup和--remove-source-files在后台运行rsync并记录日志方式

《使用nohup和--remove-source-files在后台运行rsync并记录日志方式》:本文主要介绍使用nohup和--remove-source-files在后台运行rsync并记录日... 目录一、什么是 --remove-source-files?二、示例命令三、命令详解1. nohup2.