题目:

15. 三数之和 - 力扣(LeetCode)15. 三数之和 - 给你一个整数数组 nums ,判断是否存在三元组 [nums[i], nums[j], nums[k]] 满足 i != j、i != 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 。 提示: * 3 <= nums.length <= 3000 * -105 <= nums[i] <= 105http://link.dataword.cloud/1AwrSv

总结:
这个题还是比较难的,三数之和,两数之和,看着差不多,但是要求呀这些还是很有差距的。题目描述就不多赘婿了。大家点击我的短链接就能跳过去。

这个题的解法就是排序完,利用递归并定住一个数据,将三数之和变成,两数之和,然后递归找解。


代码示例:
 

    public static List<List<Integer>> threeSum2(int[] nums){Arrays.sort(nums);List<List<Integer>> result = new LinkedList<>();dfs2(3, 0, nums.length - 1, 0, nums,new LinkedList<>(), result);return result;}public static void dfs2(int n//用来控制 递归的结束条件(找到结果有n 个数),int i//左边界,int j//右边界,int target//目标值,int[] nums,//数组LinkedList<Integer> stack,//固定的数List<List<Integer>> result//结果){if(n == 2){//递归结束标志。就剩两个数据就没必要继续了twoSum2(i, j, nums, target, stack, result);return ;}for (int k = i; k < j; k++) {if(k>i && nums[k] == nums[k-1]){ //检查 k 的有效边界,以及检查重复continue;}//固定一个数据stack.push(nums[k]);dfs2(n-1,k+1,j,target - nums[k],nums,stack,result);//弹出固定的方法stack.pop();}}//找解的核心方法static public void twoSum2(int i, int j, int[] nums, int target,LinkedList<Integer> stack,List<List<Integer>> result) {while(i<j){//保持边界int sum = nums[i]+nums[j];//调整边界if(sum < target){i++;} else if (sum > target) {j--;}else {//找到解ArrayList<Integer> list = new ArrayList<>(stack);list.add(nums[i]);list.add(nums[j]);result.add(list);//继续找(调整边界)i++;j--;//这两个是在找重复的,自己和自己前一个重复就跳走,重复没意义while (i < j && nums[i] == nums[i - 1]) {i++;}while (i < j && nums[j] == nums[j + 1]) {j--;}}}}




视频讲解:

进阶数据结构和算法-332-三数之和-Leetcode15_哔哩哔哩_bilibili进阶数据结构和算法-332-三数之和-Leetcode15是大厂必备数据结构与算法Java视频教程(下篇),java高级程序员必学的数据结构与算法的第178集视频,该合集共计200集,视频收藏或关注UP主,及时了解更多相关视频内容。http://link.dataword.cloud/3qCztX黑马讲解的很透彻,建议看看,💪

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/news/919870.shtml
繁体地址,请注明出处:http://hk.pswp.cn/news/919870.shtml
英文地址,请注明出处:http://en.pswp.cn/news/919870.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ASCOMP PDF Conversa:高效精准的PDF转换工具

在日常工作和学习中&#xff0c;PDF文件因其格式稳定、兼容性强而被广泛使用。然而&#xff0c;PDF文件的编辑性较差&#xff0c;常常需要将其转换为可编辑的格式&#xff0c;如Word文档。ASCOMP PDF Conversa作为一款功能强大的PDF转换工具&#xff0c;能够将PDF文件转换成可编…

JAVA核心基础篇-集合

想要了解集合&#xff0c;首先要知道一个东西&#xff0c;叫数据结构。所谓数据结构&#xff0c;其实就是计算机存储&#xff0c;组织数据的方式。常用的数据结构有8大类数组&#xff0c;链表&#xff0c;树&#xff0c;堆&#xff0c;栈&#xff0c;队列&#xff0c;哈希表&am…

大模型——深度评测智能体平台Coze Studio

深度评测智能体平台Coze Studio 7 月底字节跳动的 Coze-Studio 正式开源,算是 AI 智能体领域的一个大事件。这个月终于有时间在内网环境进行了部署和评测,希望能为团队的企业知识库和 AI 应用建设提供多一个选项。 其实,我们厂的知识库系统一直是自研的。没有直接采用市面…

UE5打包,LoadObject加载不出网格|动画

由于笔者UE5加载模型和动画使用的动态加载&#xff08;LoadObject&#xff09;&#xff0c;而这些资源&#xff08;XX001、XX002 等&#xff09;没有被任何关卡或蓝图直接引用&#xff0c;在编辑器状态下是可以正常加载的&#xff0c;但它们在打包时被当作“无用”资源而排除了…

C 语言标准输入输出头文件stdio.h及其常见用法

在这篇文章中&#xff0c;我们来详细聊一聊 C 语言标准输入输出头文件 stdio.h 及其常见用法。1. stdio.h 是什么 stdio.h&#xff08;Standard Input and Output Header&#xff09;是 C 标准库中的一个头文件&#xff0c;提供了处理标准输入输出和一些文件操作的函数声明。 它…

Js逆向 拼夕夕anti_content

前言 本文章中所有内容仅供学习交流使用&#xff0c;不用于其他任何目的&#xff0c;不提供完整代码&#xff0c;抓包内容、敏感网址、数据接口等均已做脱敏处理&#xff0c;严禁用于商业用途和非法用途&#xff0c;否则由此产生的一切后果均与作者无关&#xff01;本文章未经…

大模型时代为什么需要向量数据库?

这里写自定义目录标题1. 向量数据库2. 向量嵌入3. 特征和向量4. 相似性测量4.1 欧几里得距离4.2 余弦相似度5. 相似性搜索5.1 K-Means5.2 基于文本嵌入进行意图匹配6. 问答助手7. 意图匹配1. 向量数据库 向量数据库&#xff08;Vector Database&#xff09;&#xff0c;也叫矢…

【Canvas与旗帜】二十角金盘德国旗

【成图】【代码】<!DOCTYPE html> <html lang"utf-8"> <meta http-equiv"Content-Type" content"text/html; charsetutf-8"/> <head><title>多角金盘德国旗 Draft1</title><style type"text/css&qu…

Linux软件编程:总结

一、Linux系统概述&#xff08;一&#xff09;Linux系统概述&#xff08;二&#xff09;Linux系统简介1.常见的Linux系统&#xff1f;2.Linux操作系统是操作系统的核心&#xff0c;也成为内核&#xff0c;内核的主要功能&#xff1f;3.shell是操作系统的外壳&#xff0c;主要作…

【51单片机学习】直流电机驱动(PWM)、AD/DA、红外遥控(外部中断)

一、直流电机驱动&#xff08;PWM&#xff09;1.直流电机介绍步进电机的旋转速度完全由编码的通电时间决定的&#xff0c;可以用于精密控制。 舵机内部是一个直流电机加一个控制器&#xff0c;引出三根线&#xff0c;分别是正负极和编码线&#xff0c;根据输出电平的时间来控制…

ComfyUI Portrait Master肖像大师中文版

本文转载自&#xff1a;ComfyUI Portrait Master肖像大师中文版 - Hello123工具导航 ** 一、产品定位与技术架构 肖像大师中文版是专为 AI 绘画工具设计的提示词生成插件&#xff0c;通过结构化参数控制实现精准人物肖像生成。它基于 ComfyUI 平台开发&#xff0c;提供 193 国…

(Redis)内存淘汰策略

1. 为什么需要内存淘汰策略&#xff1f;Redis 是一个基于内存的高性能数据库&#xff0c;所有数据都存储在内存中。优点&#xff1a;读写速度极快。缺点&#xff1a;内存有限&#xff0c;存满之后如果继续写入&#xff0c;就必须有一套策略来决定“删掉谁&#xff0c;留下谁”。…

Eclipse 里Mybatis的xml的头部报错

需要进行Eclipse 配置 MyBatis 的DTD文件Window -> Preference -> Maven -> 勾选 (download artifact javadoc).

SpringBoot Web快速入门_从零搭建你的第一个Web应用

在 Java 企业级开发领域&#xff0c;SpringBoot 以其 “约定优于配置” 的理念彻底革新了传统 Spring 应用的开发模式。根据 2023 年 JetBrains 开发者调查报告&#xff0c;超 65% 的 Java 开发者将 SpringBoot 选为 Web 开发的首选框架。其优势显著&#xff1a;快速启动&#…

手持 Mid360 + RealSense 相机 + Jetson Orin 一体平台

这篇博客是我们开源的一个项目介绍&#xff0c;包括3D结构件 STP 文件与常见 SLAM 工程在 Arm 设备上编译手册等&#xff0c;将 Livox Mid360、Realsense 相机、Nvidia Jetson Orin、定制电池放在了一个手持设备上&#xff0c;同时这个手持设备预留了底部螺纹孔&#xff0c;当你…

H7-TOOL固件2.31发布,支持250M示波器,支持IAR下载算法加载运行,上位机支持UTF-8编码,增加多款脱机烧录芯片支持

【PC软件】V2.3.1 1. 脱机烧录功能更新: - 添加芯片: - 自动填充文件名、Flash地址、Flash大小、SRAM地址和SRAM大小 - FLM算法文件不支持自动填写文件名&#xff0c;当生成文件后需要手动更新 - 厂商列表栏鼠标右键菜单可复制厂商名 - 修复添加芯片排列次序的问题…

自然语言处理——06 迁移学习(上)

1 fasttext工具介绍 1.1 介绍 fasttext 是 Facebook AI Research&#xff08;FAIR&#xff09;开发的开源 NLP 工具包&#xff0c;专门用来解决文本相关任务&#xff0c;比如情感分析、文本分类&#xff08;判断新闻属于体育/财经等&#xff09;、识别“人名/地名”这类实体&a…

数据库MVCC是什么

问题数据库MVCC是什么我的回答MVCC&#xff0c;全称是"多版本并发控制"(Multi-Version Concurrency Control)&#xff0c;是数据库管理系统中常用的一种并发控制技术。说白了&#xff0c;它就是通过维护数据的多个版本&#xff0c;让读操作不会被写操作阻塞&#xff…

游戏广告投放数据分析项目:拆解投放的“流量密码”

用数据说话&#xff1a;1441条投放记录拆解游戏广告投放的“流量密码”一、数据概况 & 处理思路 先放一张数据全家福&#xff0c;字段 13 个&#xff0c;样本 1441 条&#xff0c;缺失值 0&#xff0c;只做了一件事&#xff1a;把“未知大小”“无”等脏数据清洗掉。 impor…

数据库服务语句应用

文章目录&#x1f31f;数据库语句应用介绍&#x1f340;数据库语句分类介绍DDL&#xff08;Data Definition Language&#xff09;数据定义语言DCL&#xff08;Data Control Language&#xff09;数据控制语言DML&#xff08;Data Manipulation Language&#xff09;数据操作语…