遍历所有排列方式

  • 前言

    • 回溯采用试错的方法解决问题,一旦发现当前步骤失败,回溯算法就返回上一个步骤,继续另一种方案继续试错。
    • 回溯算法的优点是速度快,没有尝试所有路径就可能找到答案。当然,如果运气不好,回溯算法就是一个暴力遍历(当答案就是最后一条搜索路径)。
    • 回溯算法又称为试探法,它的主要思想如上。回溯算法针对大多数问题有如下特点:问题的答案有多个元素、答案需要满足一些约束(如数独)、寻找答案的方式每个步骤相同。回溯算法逐渐构建答案,并在确定候选元素不满足约束后立即放弃候选元素,知道找到答案的所有元素。
  • 简介
    • 全排列一般答案为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遍历所有排列方式问题相关推荐

  1. 回溯算法-02遍历所有组合方式问题

    遍历所有的组合方式 简介 经典的数学组合问题,对应之前的排列问题. 问题描述 现在有四本书为A,B,C,D,要求选出两本,输出所有的选择情况. 问题分析 和之前一样,如果试求组合数目,那么DP将会是一 ...

  2. 常用十大算法 非递归二分查找、分治法、动态规划、贪心算法、回溯算法(骑士周游为例)、KMP、最小生成树算法:Prim、Kruskal、最短路径算法:Dijkstra、Floyd。

    十大算法 学完数据结构该学什么?当然是来巩固算法,下面介绍了十中比较常用的算法,希望能帮到大家. 包括:非递归二分查找.分治法.动态规划.贪心算法.回溯算法(骑士周游为例).KMP.最小生成树算法:P ...

  3. 高效 遍历 算法_一文学会回溯算法解题技巧

    (给算法爱好者加星标,修炼编程内功) 来源:码海 前言 上文我们学习了深度优先搜索和广度优先搜索,相信大家对这两者的算法有了比较清楚的认识,值得一提的,深度优先算法用到了回溯的算法思想,这个算法虽然相 ...

  4. “回溯”算法总结(深度优先遍历 + 状态重置 + 剪枝)

    地址:https://leetcode-cn.com/problems/permutations/solution/hui-su-suan-fa-python-dai-ma-java-dai-ma-b ...

  5. 回溯算法团灭子集、排列、组合问题

    回溯算法团灭子集.排列.组合问题 一.子集 给定一组不含重复元素的整数数组 nums,返回该数组所有可能的子集(幂集). 说明:解集不能包含重复的子集. 示例: 输入: nums = [1,2,3] ...

  6. java编程题身高排队_身高排队算法-(较优解):12个高矮不同的人,排成两排,每排必须是从矮到高排列,而且第二排比对应的第一排的人高,问排列方式有多少种?...

    本人对解决算法有兴趣,曾在网上看到过一道阿里巴巴的面试题. 题目是这样的:12个高矮不同的人,排成两排,每排必须是从矮到高排列,而且第二排比对应的第一排的人高,问排列方式有多少种? 所以自己也考虑了一 ...

  7. 回溯算法 与 深度优先遍历对比

    回溯算法 与 深度优先遍历对比 回溯算法与深度优先遍历 理解 搜索与遍历 与动态规划的区别 共同点 不同点 从全排列问题开始理解回溯算法 设计状态变量 代码实现 参考代码 1 (错误代码): 修改的部 ...

  8. sum 去重_总结leetcode上【排列问题】【组合问题】【子集问题】回溯算法去重的两种写法!...

    本周小结!(回溯算法系列三)续集 在 本周小结!(回溯算法系列三) 中一位录友对 整颗树的本层和同一节点的本层有疑问,也让我重新思考了一下,发现这里确实有问题,所以专门写一篇来纠正,感谢录友们的积极交 ...

  9. 应用回溯算法求全排列

    从第一位开始依次确定每一位的数字,当确定到 k 位时就分别将第 k 位及之后的数字放到第 k 位,然后按同样的方法继续确定下一位,直到最后一位被确定. 应用回溯的处理思想枚举所有的可能的排列方式. 直 ...

最新文章

  1. python生成gif【简明教程】
  2. DOS命令大全(一)
  3. SIGIR 2021|用于搜索多样化的意图图建模
  4. 分布式模式之Broker模式
  5. Adb安装程序出现TimeOut错误
  6. 字符串startswith_JavaScript字符串startsWith()方法与示例
  7. 基于MPI的H.264并行编码代码移植与优化
  8. 【机器学习】K-Means(非监督学习)学习及实例使用其将图片压缩
  9. Pycharm菜单栏消失,(File 、view消失)快速调出来的方法。(Professional Edition 2022版)
  10. 在matlab编辑大于号,教你怎么用MathType编辑大于或小于符号
  11. 随笔-学习编程有没有必要做笔记?如何做笔记?
  12. POJ 2503 Babelfish(map)
  13. 程序员的自我进化:技术的广度与深度怎么权衡
  14. 【DA】用户粘性指标:日活/月活
  15. 手摸手带你写项目----秒杀系统(一)
  16. 七夕了,男朋友说他想学学算法~
  17. 曲面电视市场日渐成熟,TCL缘何“一骑绝尘”?
  18. 高斯旋转热源与双椭球热源_【干货】论焊接,3D打印模拟的热源模型——焊缝、3D打印高度变换模拟...
  19. python中scapy模块的使用
  20. NAT与NAT穿透(一)

热门文章

  1. 阻塞队列的使用案例-注册成功后增加积分
  2. Elastic-Job配置步骤
  3. base64核心原理
  4. Request_继承体系
  5. java builder.parse_JAVA之DocumentBuilder生成解析XML
  6. 学完java学swift_前言最近学完Swift之后一直没有机会实战,发现由于Swift发展历史原因,目前网上大部分的算法都是使用C、Java或其他语言实现的,几乎没有使用Swift实...
  7. spring-DAO
  8. python字典有什么用_在Python中使用范围作为字典键,我有什么选...
  9. 04 数据操作 + 数据预处理【动手学深度学习v2】
  10. 揭秘:蚂蚁金服bPaaS究竟是什么?