算法训练营Day22

news2025/2/2 20:59:32

#Java #回溯

开源学习资料

Feeling and experiences:

进入到回溯算法的章节,在代码随想录中有详细的回溯算法理论基础

在此总结归纳:

刚开始接触到回溯时,看到了终止条件,递归调用.....等,发现了其与递归三部曲有异曲同工之妙~

回溯三部曲:

1. 路径:
• 已经做出的选择,代表了到达当前状态所经过的路径。
• 通常表示为一个列表或栈,用来保存已经做出的选择。


2. 选择列表:
• 当前可以做的选择。
• 根据问题的不同,选择列表可能会随着路径的增长而变化。
• 重要的是要从选择列表中排除那些因为已经在路径中的选择而变得不合适的选项。


3. 结束条件:
• 何时停止递归,结束当前的探索过程。
• 通常是达到了问题的解决条件,如路径长度达到某个值,或是已经检查了所有可能的选择。

组合:力扣题目链接

给定两个整数 nk,返回范围 [1, n] 中所有可能的 k 个数的组合。

你可以按 任何顺序 返回答案。

以下引用代码随想录中的图解:

代码如下:

class Solution {
    //创建一个集合,用来存放每一次组合结果
     List<List<Integer>> ans = new ArrayList<>();
     //创建一个链式集合,用来进行回溯操作
     List<Integer> path = new LinkedList<>();
    public List<List<Integer>> combine(int n, int k) {
        getCombine(n,k,1);
        return ans;
    }


    public void getCombine(int n , int k , int startIndex){
         //终止条件:当path 的大小为 k 时则要返回一次结果
         if(path.size() == k){
             ans.add(new ArrayList(path));
             return;
         }
         for(int i = startIndex; i <=n;i++){
             path.add(i);
             getCombine(n,k,i+1);
             path.removeLast();
         }
    }
}

 整体思路:

终止条件:当path的大小等于k时,将其添加到ans中,并返回上一层递归。


• 循环和递归:从startIndex遍历到n。对于每个i,执行以下操作:
• 选择:将i加入path。
• 递归:调用getCombine(n, k, i + 1)进行下一步的选择。
• 撤销选择:递归返回后,移除path的最后一个元素(这是撤销操作的核心)。

为什么在递归调用getCombine时,是 i+1,而不是 startIndex + 1 ?

  如果使用startIndex+1,每次递归调用时起始索引只会基于原始的startIndex递增,而不是基于当前选择的数字 i 。
这将导致生成重复的组合。例如,对于(n, k) = (4, 2),使用startIndex+1可能会产生两次[1, 2]的组合:一次从1开始,一次从2开始。

  使用i+1是为了在每次递归时,都是基于当前选择的数字进一步选择更大的数字,保证了组合中的数字是按照递增顺序排列的,同时避免了重复的组合。

对于剪枝优化,后面再做深入学习~

Fighting!

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

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

相关文章

PyTorch加载数据以及Tensorboard的使用

一、PyTorch加载数据初认识 Dataset:提供一种方式去获取数据及其label 如何获取每一个数据及其label 总共有多少的数据 Dataloader:为后面的网络提供不同的数据形式 数据集 在编译器中导入Dataset from torch.utils.data import Dataset 可以在jupyter中查看Dataset官方文档&…

大型医院PACS系统源码,影像存储与传输系统源码,支持多种图像处理及三维重建功能

PACS系统是医院影像科室中应用的一种系统&#xff0c;主要用于获取、传输、存档和处理医学影像。它通过各种接口&#xff0c;如模拟、DICOM和网络&#xff0c;以数字化的方式将各种医学影像&#xff0c;如核磁共振、CT扫描、超声波等保存起来&#xff0c;并在需要时能够快速调取…

基于ssm+jsp学生综合测评管理系统源码和论文

网络的广泛应用给生活带来了十分的便利。所以把学生综合测评管理与现在网络相结合&#xff0c;利用java技术建设学生综合测评管理系统&#xff0c;实现学生综合测评的信息化。则对于进一步提高学生综合测评管理发展&#xff0c;丰富学生综合测评管理经验能起到不少的促进作用。…

「完美世界」石昊调戏清漪,告白欲以身相许,渡劫神莲淬炼肉身

Hello,小伙伴们&#xff0c;我是拾荒君。 《完美世界》第142集已经更新。石昊在齐道临赠予的令牌庇护下&#xff0c;成功潜入仙池&#xff0c;借助着他的重瞳&#xff0c;他发现那神秘的渡劫神莲正位于这仙池之中。然而&#xff0c;渡劫神莲的位置上空雷云翻滚&#xff0c;宛如…

明道云引领企业变革与创新

内容来自演讲&#xff1a;周万均 | 成都护园科技有限公司 | 总经理 摘要 本文主要讲述了作者从甲方转变为乙方的角色转变过程中&#xff0c;对明道云的应用和探索。在选择系统时&#xff0c;企业会考虑的一些因素&#xff0c;并强调了团队、时间、成本和沟通等因素在企业数字化…

视图的作用及可更改性详解

一、视图的定义与作用 1.1 视图的定义 视图是数据库中的一个虚拟表&#xff0c;它是基于一个或多个表的查询结果组成的&#xff0c;通过视图可以将复杂的查询、过滤条件和连接操作封装成一个虚拟表&#xff0c;使用户可以通过查询这个虚拟表来获取数据&#xff0c;而不必了解…

【C语言】指针详解(三)

1.指针运算 指针的基本运算有三种&#xff0c;分别是:⭐指针-整数 ⭐指针-指针 ⭐指针的关系运算 1.1指针 - 整数 因为数组在内存中是连续存放的&#xff0c;只要知道第一个元素的地址&#xff0c;顺藤摸瓜就能找到后面的所有元素。 int arr[10]{1,2,3,4,5,6,7,8,9,10} #inc…

机器学习 深度学习 神经网络

神经网络概念&#xff1a; 神经网络是一个由生物神经元组成的网络或电路&#xff0c;或者从现代意义上讲&#xff0c;是一个由人工神经元或节点组成的人工神经网络。因此&#xff0c;一个神经网络要么是由生物神经元组成的生物神经网络&#xff0c;要么是用于解决人工智能&…

多臂老虎机算法步骤

内容导航 类别内容导航机器学习机器学习算法应用场景与评价指标机器学习算法—分类机器学习算法—回归机器学习算法—聚类机器学习算法—异常检测机器学习算法—时间序列数据可视化数据可视化—折线图数据可视化—箱线图数据可视化—柱状图数据可视化—饼图、环形图、雷达图统…

零基础制作宠物用品小程序

随着人们对宠物用品的需求不断增长&#xff0c;越来越多的人开始探索如何制作一个专业的宠物用品小程序。而乔拓云作为一款功能强大的在线商城制作工具&#xff0c;成为了许多商家的首选。本文将详细介绍如何使用乔拓云制作宠物用品小程序&#xff0c;让你轻松上手&#xff0c;…

VScode配置C环境

一、下载vscode https://code.visualstudio.com/ 安装完成 tips&#xff1a;如果不喜欢看英文&#xff0c;可以给VSCode进行汉化&#xff0c;需要安装插件Chinese&#xff0c;安装之后会显示让你重启VScode 二、安装C/C插件和Code Runner插件 三、下载minGw MinGW全称Minima…

TrustZone之示例用例——加密文件系统

移动设备如智能手机包含大量个人数据。如果设备丢失或被盗&#xff0c;用户会关心这些数据的机密性。这就是为什么大多数最新的设备支持文件系统加密的原因。TrustZone 可以作为保护这些数据的解决方案的一部分。 存储在外部闪存中的数据是加密的。在启动时&#xff0c;设备对用…

2024 Move 开发者大会火热报名中!1 月 13 至 14 日上海见

2024 Move 开发者大会将于 1 月 13 日至 1 月 14 日在上海举办。本届 Move 开发者大会以 “Move 生态关键的一年” 为主题&#xff0c;由 MoveFuns 、OpenBuild 和 MoveBit 主办&#xff0c;Rooch、AptosGlobal、alcove、zkMove、云赛空间和 TinTinLand 协办&#xff0c;并得到…

SpringBoot找不到或无法加载主类

1&#xff0c;bug贴图 2&#xff0c;问题说明 之所以导致这个问题是因为新建项目的时候&#xff0c;项目目录是这样的com.lab.hei.springboot.dubbo.ProviderApplication 我觉得这个目录太长了&#xff0c;所以修改了目录&#xff0c;修改后cn.alisa.springboot.dubbo.Provider…

【第七在线】商品计划的未来:数字化技术与创新趋势展望

在服装行业&#xff0c;商品计划是一项至关重要的活动&#xff0c;涉及到市场分析、库存管理、生产计划和销售策略等多个方面。然而&#xff0c;随着科技的快速发展和消费者需求的变化&#xff0c;商品计划也在不断演变。本文将深入探讨数字化技术和创新趋势如何塑造了商品计划…

从零学算法5

5.给你一个字符串 s&#xff0c;找到 s 中最长的回文子串。 如果字符串的反序与原始字符串相同&#xff0c;则该字符串称为回文字符串。 示例 1&#xff1a; 输入&#xff1a;s “babad” 输出&#xff1a;“bab” 解释&#xff1a;“aba” 同样是符合题意的答案。 示例 2&…

Drupal 远程代码执行 CVE-2019-6340 已亲自复现

Drupal 远程代码执行 CVE-2019-6340 已亲自复现 漏洞名称漏洞描述影响版本 漏洞复现环境搭建 修复建议总结 漏洞名称 漏洞描述 Drupal是一个开源且以PHP语言写成的内容管理框架(CMF) 研究人员发现Drupal存在安全漏洞(CVE-2019-6340)&#xff0c;当攻击者以PATCH或POST方式传送…

【数据结构】什么是树?

&#x1f984;个人主页:修修修也 &#x1f38f;所属专栏:数据结构 ⚙️操作环境:Visual Studio 2022 &#x1f4cc;树的定义 树(Tree)是n(n≥0)个结点的有限集.n0时称为空树. 在任意一颗非空树中: 有且仅有一个特定的称为根(Root)的结点;当n>1时,其余结点可分为m(m>0)个互…

flutter开发实战-设置bottomNavigationBar中间按钮悬浮效果

flutter开发实战-设置bottomNavigationBar中间按钮悬浮的效果 在使用tabbar时候&#xff0c;可以使用bottomNavigationBar来设置中间凸起的按钮&#xff0c;如下 一、效果图 中间按钮凸起的效果图如下 二、实现代码 我们使用BottomAppBar 一个容器&#xff0c;通常与[Sscaf…

AcWing算法提高课-1.4.2股票买卖 IV

算法提高课整理 CSDN个人主页&#xff1a;更好的阅读体验 原题链接 题目描述 给定一个长度为 n n n 的数组&#xff0c;数组中的第 i i i 个数字表示一个给定股票在第 i i i 天的价格。 设计一个算法来计算你所能获取的最大利润&#xff0c;你最多可以完成 k k k 笔交易…