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

相关文章

Rust 智能指针的使用详解

《Rust智能指针的使用详解》Rust智能指针是内存管理核心工具,本文就来详细的介绍一下Rust智能指针(Box、Rc、RefCell、Arc、Mutex、RwLock、Weak)的原理与使用场景,... 目录一、www.chinasem.cnRust 智能指针详解1、Box<T>:堆内存分配2、Rc<T>:

docker编写java的jar完整步骤记录

《docker编写java的jar完整步骤记录》在平常的开发工作中,我们经常需要部署项目,开发测试完成后,最关键的一步就是部署,:本文主要介绍docker编写java的jar的相关资料,文中通过代... 目录all-docker/生成Docker打包部署文件配置服务A的Dockerfile (a/Docke

MySQL使用EXISTS检查记录是否存在的详细过程

《MySQL使用EXISTS检查记录是否存在的详细过程》EXISTS是SQL中用于检查子查询是否返回至少一条记录的运算符,它通常用于测试是否存在满足特定条件的记录,从而在主查询中进行相应操作,本文给大... 目录基本语法示例数据库和表结构1. 使用 EXISTS 在 SELECT 语句中2. 使用 EXIS

基于Spring Boot 的小区人脸识别与出入记录管理系统功能

《基于SpringBoot的小区人脸识别与出入记录管理系统功能》文章介绍基于SpringBoot框架与百度AI人脸识别API的小区出入管理系统,实现自动识别、记录及查询功能,涵盖技术选型、数据模型... 目录系统功能概述技术栈选择核心依赖配置数据模型设计出入记录实体类出入记录查询表单出入记录 VO 类(用于

java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)

《java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)》:本文主要介绍java中pdf模版填充表单踩坑的相关资料,OpenPDF、iText、PDFBox是三... 目录准备Pdf模版方法1:itextpdf7填充表单(1)加入依赖(2)代码(3)遇到的问题方法2:pd

Zabbix在MySQL性能监控方面的运用及最佳实践记录

《Zabbix在MySQL性能监控方面的运用及最佳实践记录》Zabbix通过自定义脚本和内置模板监控MySQL核心指标(连接、查询、资源、复制),支持自动发现多实例及告警通知,结合可视化仪表盘,可有效... 目录一、核心监控指标及配置1. 关键监控指标示例2. 配置方法二、自动发现与多实例管理1. 实践步骤

在Spring Boot中集成RabbitMQ的实战记录

《在SpringBoot中集成RabbitMQ的实战记录》本文介绍SpringBoot集成RabbitMQ的步骤,涵盖配置连接、消息发送与接收,并对比两种定义Exchange与队列的方式:手动声明(... 目录前言准备工作1. 安装 RabbitMQ2. 消息发送者(Producer)配置1. 创建 Spr

k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)

《k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)》本文记录在K8s上运行的MySQL/MariaDB备份方案,通过工具容器执行mysqldump,结合定时任务实... 目录前言一、获取需要备份的数据库的信息二、备份步骤1.准备工作(X86)1.准备工作(arm)2.手

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

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

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

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