LeetCode刷题之HOT100之组合总和

2024/6/3 周一,工作日的第一天。昨晚梦到被导师说去实验室不积极哈哈哈,风扇开到二级,早上被吹醒。买的书马上快要到了。上午刚来准备刷题,结果去搞了一下数据库sql,做的差不多了,还差点格式转换就差不多出回来了。现在来做题。

1、题目描述

在这里插入图片描述

2、逻辑分析

无重复数组,给一个目标值target,要求在数组中找出可以使数字和等于target的所有不同组合,且数组中的元素可以被重复使用。那么怎么解呢?我没有头绪,看看题解怎么说。官方题解给出算法是使用搜索回溯的方法,里面涉及到深度优先搜索递归计算。大致思路:将整个搜索过程用一个树来表达,即如下图呈现,每次的搜索都会延伸出两个分叉,直到递归的终止条件,这样我们就能不重复且不遗漏地找到所有可行解:
在这里插入图片描述
像上图中所示:一个个数计算,这样就不会有被遗漏的元素了。下面看具体代码实现。

3、代码演示

public List<List<Integer>> combinationSum(int[] candidates, int target) {// 创建一个结果列表,用于存储所有可能的组合List<List<Integer>> res = new ArrayList<List<Integer>>();// 创建一个临时列表,用于存储当前正在构建的组合List<Integer> combina = new ArrayList<>();// 调用深度优先搜索方法,开始搜索所有可能的组合dfs( candidates,  target, res , combina, 0);// 返回结果列表 return res;}// 深度优先搜索方法,用于递归地搜索所有可能的组合public void dfs(int[] candidates, int target, List<List<Integer>> res , List<Integer> combina, int index){// 如果已经遍历完所有的候选数字,则直接返回if(index == candidates.length){return;}// 如果当前组合的数字之和已经等于目标值target,则将当前组合添加到结果列表中,并返回 if(target == 0){res.add(new ArrayList<Integer> (combina));return;}// 不选择当前数字,继续搜索下一个数字dfs(candidates, target, res, combina, index + 1);// 如果目标值target减去当前数字仍然大于等于0,则可以选择当前数字if(target - candidates[index] >= 0){// 将当前数字添加到当前组合中 combina.add(candidates[index]);// 递归调用dfs,目标值变为target减去当前数字 dfs(candidates,target - candidates[index], res, combina, index);// 回溯,将当前数字从组合中移除,以便尝试其他组合combina.remove(combina.size() - 1);}}

时间复杂度:O(S),其中 S 为所有可行解的长度之和。空间复杂度:O(target)。
边看边敲完这段代码,大致意思明了,但是对一些细枝末节的地方还是稍有欠缺,先放一放,下次再来看看。搞了几天的后端结果发现搞错了哈哈,只能重新开始啦,悲惨滴我呜呜呜。再见啦!

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

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

相关文章

springboot打包笔记

文章目录 多配置文件application.yml本地启动参数替换profiles&#xff0c;还是要复制文件 项目有各种环境&#xff0c;例如&#xff1a;local&#xff0c;uat&#xff0c;prd等。 各种打包方式一定要熟练掌握。 做此笔记是因为做了那么多项目&#xff0c;也打了很多包&#xf…

QT中如何对引入的第三方库进行翻译

1、背景 在我们的程序中,可能会加载其他人写的模块,,该模块是以库的形式提供的,那么我们程序翻译时,如何来对引入的第三方库进行翻译??? 2、方案 首先,第三方库会有自己的翻译文件,并且一般要给我们提供设置翻译的接口, 例如下:第三方库给我们暴露一个接口,我们…

军用电源性能测试有哪些测试项目?需要遵循什么标准?

为了确保军用电源在极端条件下能够正常工作&#xff0c;必须对其进行一系列严格的性能测试。这些测试不仅包括效率、电压调整率和负载调整率等基本参数的测试&#xff0c;还包括动态响应能力、绝缘电阻、耐压测试、温度系数以及高低温循环等综合性能的评估。 测试项目 效率 电压…

spring 优雅替换bean

方案一&#xff1a;使用 Primary/Qualifier 注解&#xff08;优选&#xff09; 如果有多个相同类型的 Bean 存在&#xff0c;可以将想要优先使用的 Bean 加上 Primary 注解。 Qualifier和Primary注解的区别&#xff1a;Primary注解用于标记具有相同类型的多个实例中的主要实例…

MySQL -- 连接查询

MySQL使用连接查询&#xff08;JOIN&#xff09;是为了从多个相关表中获取数据。连接查询是一种强大且常用的操作&#xff0c;可以根据某些条件将两张或多张表中的数据组合在一起&#xff0c;返回一个联合结果集。 1.为什么使用连接查询 数据规范化&#xff1a; 数据库设计时通…

站点被篡改快照被劫持解决服务方法教程_一招制敌

站点被篡改快照被劫持解决服务方法教程_一招制敌 被篡改表现形式&#xff1a; 站点打不开或跳转到别的网站。 攻击者目的&#xff1a; 报复、勒索、卖防御产品&#xff08;如DDOS防御产品&#xff09;。 攻击成本&#xff1a; 工具&#xff08;如VPN购买&#xff09;成本、人…

智能工厂生产设备实时监控技术的UI设计

智能工厂生产设备实时监控技术的UI设计

Flutter的Dart语法入门

文章目录 前言1. 类型声明2. 数据类型2.1 基本数据类型常量 2.2 String2.3 集合2.4 unicode 3. Dart函数特征3.1 可变参数列表和默认入参3.2 匿名函数3.3 typedef 4. Dart面向对象4.1 构造函数4.2 访问权限4.3 类的继承 参考资料附录 前言 每个语言都有控制流语句就不写测试代…

Go 语言的控制结构:条件与循环

Go 语言提供了丰富的控制结构&#xff0c;使得开发者可以编写出具有复杂逻辑的程序。这些控制结构包括用于条件分支的 if-else 和 switch 语句&#xff0c;循环控制的 for 语句&#xff0c;以及用于控制循环执行流的 break 和 continue 关键字。此外&#xff0c;Go 语言还支持 …

约瑟夫游戏(编号+密码)

编号为1、2、3、...、N的N个人按顺时针方向围坐一圈&#xff0c;每人持有一个密码&#xff08;正整数&#xff09;。从指定编号为1的人开始&#xff0c;他的密码为M的初始值&#xff0c;按顺时针方向从1号自己开始顺序报数&#xff0c;报到指定数M时停止报数&#xff0c;报M的人…

i18n-demo

一、demo 1、资源文件准备 resources下放各个语言文件&#xff0c;直接放resources下都行。我新建一个文件夹&#xff0c;

房地产vr全景展示交互视频让购房者更有参与感

在当今房地产市场中&#xff0c;购房者的需求日益多样化和个性化。为满足这一趋势&#xff0c;我们创新性地将VR虚拟现实技术应用于楼盘宣传&#xff0c;为购房者带来前所未有的沉浸式购房体验。 一、地理位置全景展示 通过实景拍摄与VR技术的结合&#xff0c;我们为购房者呈现…

day26-单元测试

1. 单元测试Junit 1.1 什么是单元测试&#xff1f;&#xff08;掌握&#xff09; 1.2 Junit的特点&#xff1f;&#xff08;掌握&#xff09; 1.3 基本用法&#xff1a;&#xff08;掌握&#xff09; 实际开发中单元测试的使用方式&#xff08;掌握&#xff09; public class …

C语言,排序

前言 排序&#xff0c;可以说是数据结构中必不可缺的一环。我们创造数据存储它&#xff0c;要想知道数据之间的联系&#xff0c;比较是必不可少的。不然&#xff0c;费劲心思得来的数据若是不能有更多的意义&#xff0c;那么拿到了又有什么用&#xff1f; 排序是计算机内经常进…

风险投资公司正在帮助小投资者购买Anthropic、OpenAI等热门公司的股票

近年来&#xff0c;风险投资公司对于人工智能&#xff08;AI&#xff09;领域的公司&#xff0c;如Anthropic、Groq、OpenAI等&#xff0c;表现出了极高的投资热情。这些公司因为它们在AI技术方面的创新而备受瞩目。但是&#xff0c;对于很多小投资者来说&#xff0c;由于资金有…

[C#]使用C#部署yolov8的目标检测tensorrt模型

【测试通过环境】 win10 x64 vs2019 cuda11.7cudnn8.8.0 TensorRT-8.6.1.6 opencvsharp4.9.0 .NET Framework4.7.2 NVIDIA GeForce RTX 2070 Super 版本和上述环境版本不一样的需要重新编译TensorRtExtern.dll&#xff0c;TensorRtExtern源码地址&#xff1a;TensorRT-CShar…

期权的权利金怎么算的

期权权利金的计算涉及多个因素&#xff0c;包括敲定价格、到期时间以及整个期权合约的具体情况。期权的权利金具体的计算公式和因素可能因不同的期权合约和市场条件而有所不同&#xff0c;下文为大家介绍期权的权利金怎么算的 &#xff1f;本文来自&#xff1a;期权酱 一、期权…

【LeetCode】二叉树oj专题

如有不懂的地方&#xff0c;可查阅往期相关文章&#xff01; 个人主页&#xff1a;小八哥向前冲~ 所属专栏&#xff1a;数据结构【c语言】 目录 单值二叉树 对称二叉树 计算二叉树的深度 二叉树的前序遍历 相同二叉树 另一棵树的子树 二叉树的构建和遍历 翻转二叉树 判…

spring boot 中的异步@Async

spring boot 开启异步调用 1、启动类上添加EnableAsync注解&#xff0c;表示启动异步 2、在具体实现异步的方法上添加Async注解 package com.example.demo;import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootAppli…

YOLOv3+mAP实现金鱼检测

YOLOv3mAP实现金鱼检测 Git源码地址&#xff1a;传送门 准备数据集 按帧数读取视频保存图片 video2frame.py使用labelimg标注工具对图片进行标注统一图片大小为 416x416&#xff0c;并把标签等信息写成.xml文件 conver_point.py读取缩放后的标签图片&#xff0c;转为左上角右下…