搜索与回溯算法②

求0-9的数字可以组成的所有k 位数。

def backtrack(start, path, k, n, results):"""核心函数。:param start: 下一个添加的数字的起始位置:param path: 当前构建的路径,代表一个组合:param k: 组合中所需的数字个数:param n: 可选数字的最大值:param results: 存储所有有效组合的列表"""# 如果路径长度等于k,说明找到了一个有效的k位数,将其加入结果列表if len(path) == k:results.append("".join(map(str, path)))return# 从start开始,尝试每个可能的数字for i in range(start, n + 1):# 添加当前数字到路径path.append(i)# 继续递归填充下一个数字,注意数字可以重复使用,所以起始位置仍然是startbacktrack(start, path, k, n, results)# 回溯,移除路径中的最后一个数字,尝试下一个可能的数字path.pop()def generate_combinations(k, n=9):"""生成所有可能的k位数组合。:param k: 组合中所需的数字个数:param n: 可选数字的最大值,默认为9:return: 包含所有k位数的列表"""results = []  # 存储所有组合的结果列表backtrack(0, [], k, n, results)  # 从数字0开始进行回溯return results# 示例:生成所有3位数
k_digit_numbers = generate_combinations(3)
for number in k_digit_numbers:print(number)

        在这个案例中,`generate_combinations` 函数是主函数,它初始化结果列表并开始回溯过程。`backtrack` 函数是核心,它尝试所有可能的数字,并在找到一个有效的`k`位数时将其存储。通过递归调用自身,`backtrack` 函数能够探索所有可能的组合。当路径(`path`)达到长度`k`时,我们就找到了一个有效的组合,并将其添加到结果列表中。

        在每次递归调用之后,我们通过`path.pop()`来回溯,这样就可以去掉最后一个数字并尝试其他可能的数字。

        这个代码片段将生成所有可能的`k`位数,其中数字可以重复,并且是从0开始的。如果想要不重复的数字或者有其他特定的约束条件,可以修改`backtrack`函数来适应这些规则。

关于回溯和剪枝

此案例中,回溯和剪枝的操作如下所述:

        回溯(Backtracking):

        a.回溯是在`backtrack`函数中发生的,特别是在递归调用之后,通过`path.pop()`移除路径上的最后一个数字。这样做是为了撤销上一步的操作,可以尝试其他可能的数字,这是回溯算法的基本特征。

        b.回溯算法通过递归来实现深度优先搜索,在搜索空间树的每一层尝试所有可能的选项。当它达到一个节点(在这个例子中是一个特定长度的数字组合),它会检查节点是否满足约束(在这里是长度等于`k`)。如果满足,则记录下来;如果不满足,则返回上一层,尝试其他选项。

path.append(i)  # 尝试加入一个数字到当前路径backtrack(start, path, k, n, results)  # 递归调用以继续构建路径path.pop()  # 移除最后一个元素,这是回溯的体现

        剪枝(Pruning):

       a. 在这个特定的例子中,剪枝不是特别明显,因为我们要生成所有可能的组合,而且没有明确的约束条件来剪除某些分支。但是,可以认为在达到组合的长度等于`k`时停止进一步递归的操作是一种隐性的剪枝。这是因为任何超过`k`长度的路径都不会是有效的解,所以不再继续在那个方向上探索。

       b. 剪枝通常用于减少搜索空间,避免不必要的计算。在其他问题中,如果有额外的约束条件,比如数字不能重复,或者组合必须满足某种特定的性质,那么需要在递归之前检查这些条件,并且只在条件满足的情况下继续递归。

        在这段代码中,由于我们要求所有可能的`k`位数,没有进一步的约束条件,所以没有进行显式的剪枝操作。如果要添加剪枝,我们需要在递归调用`backtrack`之前加入检查逻辑,以确保只有满足条件的分支才会被探索。

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

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

相关文章

Python编程技巧:多层for循环的高级应用

更多资料获取 📚 个人网站:ipengtao.com Python的for循环结构是编程中最基础也是最常用的控制结构之一。通过for循环,可以轻松遍历数据集合和执行重复的操作。然而,当我们面对多层for循环时,性能和可读性可能会成为挑…

linux使用逻辑券lvm进行磁盘管理

lvm的安装 在线安装 yum install lvm2 离线安装,下载后执行 rpm -ivh * --nodeps --force 在如下网站中挨个下载http://mirrors.163.com/centos/7/os/x86_64/Packages/ device-mapper-1.02.170-6.el7_9.5.x86_64.rpm device-mapper-event-1.02.170-6.el…

A-B 数对

A-B 数对 题目背景 出题是一件痛苦的事情! 相同的题目看多了也会有审美疲劳,于是我舍弃了大家所熟悉的 AB Problem,改用 A-B 了哈哈! 题目描述 给出一串正整数数列以及一个正整数 C C C,要求计算出所有满足 A −…

Redis的三种消息队列实现方式

目录 前言 List实现消息队列 PubSub消息队列 Stream消息队列 三种实现方式对比 前言 为什么要使用Redis的消息队列? 成本低,对于RabbitMQ或是Kafka来说,已经是重量级的消息队列。 Redis的三种实现方式: List结构&#xff1…

形态学操作—形态学梯度

形态学梯度(Morphological Gradient)是图像形态学处理中的一种操作,它通过对图像的膨胀和腐蚀操作之间的差异来突出图像中的边缘信息。这种操作有助于增强图像中物体的边界,使它们更加突出。   在数学上,形态学梯度的…

【安卓12源码】WMS系列:addWindow 和 removeWindow流程

一、Window 的属性 Window的属性定义在WindowManager的内部类LayoutParams中,了解Window的属性能够更好的理解WMS的内部原理。Window的属性有很多种,与应用开发最密切的有三种,它们分别是Type(Window的类型)、Flag(Window的标志)和SoftInputM…

SMART PLC温度采集模块温度转换FC(梯形图+SCL代码)

对于模拟量输入采集,温度变送器等我们可以利用线性转换功能块完成温度采集,西门子PLC有温度采集模块,利用温度采集模块采集温度我们的转换关系无需进行线性变换,下面我们具体介绍。温度采集线性转换功能块请参考下面的文章链接: https://rxxw-control.blog.csdn.net/arti…

Hadoop学习笔记(HDP)-Part.06 安装OracleJDK

目录 Part.01 关于HDP Part.02 核心组件原理 Part.03 资源规划 Part.04 基础环境配置 Part.05 Yum源配置 Part.06 安装OracleJDK Part.07 安装MySQL Part.08 部署Ambari集群 Part.09 安装OpenLDAP Part.10 创建集群 Part.11 安装Kerberos Part.12 安装HDFS Part.13 安装Ranger …

代码随想录二刷 | 栈与队列 |用栈实现队列

代码随想录二刷 | 栈与队列 |用栈实现队列 题目描述解题思路 & 代码实现 题目描述 232.用栈实现队列 请你仅使用两个栈实现先入先出队列。队列应当支持一般队列支持的所有操作(push、pop、peek、empty): 实现 M…

外包干了8个月,技术退步明显.......

先说一下自己的情况,大专生,18年通过校招进入武汉某软件公司,干了接近4年的功能测试,今年年初,感觉自己不能够在这样下去了,长时间呆在一个舒适的环境会让一个人堕落! 而我已经在一个企业干了四年的功能测…

undo log 具体怎么回滚事务,如何查询慢 SQL 产生的原因

文章目录 undo log 具体怎么回滚事务 ?如何查询慢 SQL 产生的原因 简单来看两个问题: undo log 具体怎么回滚事务 ? 举个例子: 对于 insert 类型的 sql,会在 undo log 中记录下方才你 insert 进来的数据的 ID&#x…

HarmonyOS带大家创建自己的第一个Page页面并实现路由跳转

我们 在开发过程中 经常会看到 被 艾特修饰的代码 有限像 java中的注解 在 harmonyOS 中 这叫 装饰器 被关键字装饰取来的代码 会具备某某功能 我们这里先来创建一个新的界面 在pages 目录下 右键 如下图 选择page创建 这里 我们取名叫 AppView 然后点击右下角 Finish 这样…

Scala--2

package scala02object Scala07_typeCast {def main(args: Array[String]): Unit {// TODO 隐式转换// 自动转换val b: Byte 10var i: Int b 10val l: Long b 10 100Lval fl: Float b 10 100L 10.5fval d: Double b 10 100L 10.5f 20.00println(d.getClass…

P1006 [NOIP2008 提高组] 传纸条

洛谷的题 网址:P1006 [NOIP2008 提高组] 传纸条 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 还是动态规划,这题和我上一篇博客写的题差不多 区别在于,这个地图不再是方阵,路线不能交叉,而且地图的大小可能大得多…

2023年甘肃省职业院校技能大赛(中职教师组)网络安全竞赛样题(二)

2023年甘肃省职业院校技能大赛(中职教师组) 网络安全竞赛样题(二) (总分1000分) 目录 模块A 基础设施设置与安全加固 A-1任务一 登录安全加固(Windows,Linux) A-2任…

如何通过Java的iTextPDF库制作一个PDF表格模板并填充数据

要使用Java的iTextPDF库制作一个PDF表格模板并填充数据&#xff0c;你需要遵循以下步骤&#xff1a; 添加依赖&#xff1a;首先&#xff0c;确保你的项目中包含了iTextPDF库的依赖。如果你使用Maven&#xff0c;可以在你的pom.xml文件中添加以下依赖&#xff1a; <depende…

IDEA中,光标移动快捷键(Shift + 滚轮前后滚动:当前文件的横向滚动轴滚动。)

除此之外&#xff0c;其他常用的光标移动快捷键包括&#xff1a; Shift 滚轮前后滚动&#xff1a;当前文件的横向滚动轴滚动。Shiftenter&#xff1a;快速将鼠标移动到下一行。Ctrl ]&#xff1a;移动光标到当前所在代码的花括号结束位置。Ctrl 左方向键&#xff1a;光标跳转…

Linux内核同步与互斥机制介绍

在内核中&#xff0c;可能出现多个进程&#xff08;通过系统调用进入内核模式&#xff09;访问同一个对象、进程和硬中断访问同一个对象、进程和软中断访问同一个对象、多个处理器访问同一个对象等现象&#xff0c;我们需要使用互斥技术&#xff0c;确保在给定的时刻只有一个主…

内衣迷你洗衣机什么牌子好?好用不贵的内衣洗衣机推荐

由于内衣洗衣机在目前的市场上越来越受欢迎&#xff0c;使得不少的小伙伴都在犹豫要不要为自己入手一台专用的内衣洗衣机&#xff0c;专门来清洗一些内衣裤等等贴身衣物&#xff0c;这个问题的答案是很有必要的&#xff0c;因为目前市场上的家用大型洗衣机对衣物只能够起到清洁…

SpringBoot_02

Web后端开发_07 SpringBoot_02 SpringBoot原理 1.配置优先级 1.1配置 SpringBoot中支持三种格式的配置文件&#xff1a; application.propertiesapplication.ymlapplication.yaml properties、yaml、yml三种配置文件&#xff0c;优先级最高的是properties 配置文件优先级…