回溯算法-01遍历所有排列方式问题
遍历所有排列方式
- 前言
- 回溯采用试错的方法解决问题,一旦发现当前步骤失败,回溯算法就返回上一个步骤,继续另一种方案继续试错。
- 回溯算法的优点是速度快,没有尝试所有路径就可能找到答案。当然,如果运气不好,回溯算法就是一个暴力遍历(当答案就是最后一条搜索路径)。
- 回溯算法又称为试探法,它的主要思想如上。回溯算法针对大多数问题有如下特点:问题的答案有多个元素、答案需要满足一些约束(如数独)、寻找答案的方式每个步骤相同。回溯算法逐渐构建答案,并在确定候选元素不满足约束后立即放弃候选元素,知道找到答案的所有元素。
- 简介
- 全排列一般答案为n!种方案,但是当想知道所有的排列方式的时候,DP等算法就不是那么合适了。此时回溯将是不错的选择。
- 问题描述
- 有四本书A,B,C,D,一次只能从图书馆借一本,试问有多少种借书方式?
- 问题分析
- 这个问题很简单,不妨认为有4个空位,第一个位置选择了A,那么第二个位置剩下三种选择,假设第二个位置选择了B,第三个位置剩下两种选择,以此类推。显然,单纯写这个代码是个四层循环,这样写不仅编码困难,对其他问题还要重新编码并且必须要知道输入数组的长度,这不是想要的解法。
- 其实再看看这个循环,它们都很类似。
- 选择第一本书有4中选择,答案就是这四种选择各结尾增加剩下的三本书的排列情况,那么只需要知道剩余三本书的排列集合就行了。
- 排列剩下的三本书的时候,对第一本有三种选择,只需要知道剩下两种排列情况即可。
- 最后,排两本书的时候,只需要知道最后一本是什么就行了。
- 其实就是一个大问题套着小问题,问题都是一个问题,参数有所不同罢了,问题是一样的:输出排序集合。
- 带修改参数递归很适合实现这样的问题。
- 代码
# -*-coding:utf-8-*-result = []def solve(array, solution):global resultif len(array) == 0:# 表示所有书都分配完毕,输出答案result.append(solution)returnfor i in range(len(array)):new_solution = solution + [array[i]]new_array = array[:i] + array[i+1:]solve(new_array, new_solution)if __name__ == '__main__':input = ['A', 'B', 'C', 'D']solve(input, [])for item in result:print(item)print("共{}种排列".format(len(result)))
- 运行结果
- 补充说明
- 具体代码可以查看我的Github,欢迎Star或者Fork
- 参考书《你也能看得懂的Python算法书》
- 书中错误已经修改
回溯算法-01遍历所有排列方式问题相关推荐
- 回溯算法-02遍历所有组合方式问题
遍历所有的组合方式 简介 经典的数学组合问题,对应之前的排列问题. 问题描述 现在有四本书为A,B,C,D,要求选出两本,输出所有的选择情况. 问题分析 和之前一样,如果试求组合数目,那么DP将会是一 ...
- 常用十大算法 非递归二分查找、分治法、动态规划、贪心算法、回溯算法(骑士周游为例)、KMP、最小生成树算法:Prim、Kruskal、最短路径算法:Dijkstra、Floyd。
十大算法 学完数据结构该学什么?当然是来巩固算法,下面介绍了十中比较常用的算法,希望能帮到大家. 包括:非递归二分查找.分治法.动态规划.贪心算法.回溯算法(骑士周游为例).KMP.最小生成树算法:P ...
- 高效 遍历 算法_一文学会回溯算法解题技巧
(给算法爱好者加星标,修炼编程内功) 来源:码海 前言 上文我们学习了深度优先搜索和广度优先搜索,相信大家对这两者的算法有了比较清楚的认识,值得一提的,深度优先算法用到了回溯的算法思想,这个算法虽然相 ...
- “回溯”算法总结(深度优先遍历 + 状态重置 + 剪枝)
地址:https://leetcode-cn.com/problems/permutations/solution/hui-su-suan-fa-python-dai-ma-java-dai-ma-b ...
- 回溯算法团灭子集、排列、组合问题
回溯算法团灭子集.排列.组合问题 一.子集 给定一组不含重复元素的整数数组 nums,返回该数组所有可能的子集(幂集). 说明:解集不能包含重复的子集. 示例: 输入: nums = [1,2,3] ...
- java编程题身高排队_身高排队算法-(较优解):12个高矮不同的人,排成两排,每排必须是从矮到高排列,而且第二排比对应的第一排的人高,问排列方式有多少种?...
本人对解决算法有兴趣,曾在网上看到过一道阿里巴巴的面试题. 题目是这样的:12个高矮不同的人,排成两排,每排必须是从矮到高排列,而且第二排比对应的第一排的人高,问排列方式有多少种? 所以自己也考虑了一 ...
- 回溯算法 与 深度优先遍历对比
回溯算法 与 深度优先遍历对比 回溯算法与深度优先遍历 理解 搜索与遍历 与动态规划的区别 共同点 不同点 从全排列问题开始理解回溯算法 设计状态变量 代码实现 参考代码 1 (错误代码): 修改的部 ...
- sum 去重_总结leetcode上【排列问题】【组合问题】【子集问题】回溯算法去重的两种写法!...
本周小结!(回溯算法系列三)续集 在 本周小结!(回溯算法系列三) 中一位录友对 整颗树的本层和同一节点的本层有疑问,也让我重新思考了一下,发现这里确实有问题,所以专门写一篇来纠正,感谢录友们的积极交 ...
- 应用回溯算法求全排列
从第一位开始依次确定每一位的数字,当确定到 k 位时就分别将第 k 位及之后的数字放到第 k 位,然后按同样的方法继续确定下一位,直到最后一位被确定. 应用回溯的处理思想枚举所有的可能的排列方式. 直 ...
最新文章
- python生成gif【简明教程】
- DOS命令大全(一)
- SIGIR 2021|用于搜索多样化的意图图建模
- 分布式模式之Broker模式
- Adb安装程序出现TimeOut错误
- 字符串startswith_JavaScript字符串startsWith()方法与示例
- 基于MPI的H.264并行编码代码移植与优化
- 【机器学习】K-Means(非监督学习)学习及实例使用其将图片压缩
- Pycharm菜单栏消失,(File 、view消失)快速调出来的方法。(Professional Edition 2022版)
- 在matlab编辑大于号,教你怎么用MathType编辑大于或小于符号
- 随笔-学习编程有没有必要做笔记?如何做笔记?
- POJ 2503 Babelfish(map)
- 程序员的自我进化:技术的广度与深度怎么权衡
- 【DA】用户粘性指标:日活/月活
- 手摸手带你写项目----秒杀系统(一)
- 七夕了,男朋友说他想学学算法~
- 曲面电视市场日渐成熟,TCL缘何“一骑绝尘”?
- 高斯旋转热源与双椭球热源_【干货】论焊接,3D打印模拟的热源模型——焊缝、3D打印高度变换模拟...
- python中scapy模块的使用
- NAT与NAT穿透(一)
热门文章
- 阻塞队列的使用案例-注册成功后增加积分
- Elastic-Job配置步骤
- base64核心原理
- Request_继承体系
- java builder.parse_JAVA之DocumentBuilder生成解析XML
- 学完java学swift_前言最近学完Swift之后一直没有机会实战,发现由于Swift发展历史原因,目前网上大部分的算法都是使用C、Java或其他语言实现的,几乎没有使用Swift实...
- spring-DAO
- python字典有什么用_在Python中使用范围作为字典键,我有什么选...
- 04 数据操作 + 数据预处理【动手学深度学习v2】
- 揭秘:蚂蚁金服bPaaS究竟是什么?