本文摘自php中文网,作者巴扎黑,侵删。
这篇文章主要介绍了Python使用回溯法解决迷宫问题,简单讲述了迷宫问题的原理并结合实例形式分析了Python基于回溯法子集树模板解决迷宫问题的相关操作技巧与注意事项,需要的朋友可以参考下本文实例讲述了Python使用回溯法解决迷宫问题。分享给大家供大家参考,具体如下:
问题
给定一个迷宫,入口已知。问是否有路径从入口到出口,若有则输出一条这样的路径。注意移动可以从上、下、左、右、上左、上右、下左、下右八个方向进行。迷宫输入0表示可走,输入1表示墙。为方便起见,用1将迷宫围起来避免边界问题。
分析
考虑到左、右是相对的,因此修改为:北、东北、东、东南、南、西南、西、西北八个方向。在任意一格内,有8个方向可以选择,亦即8种状态可选。因此从入口格子开始,每进入一格都要遍历这8种状态。
显然,可以套用回溯法的子集树模板。
注意,解的长度是不固定的。
代码
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 |
|
效果图
以上就是详解Python使用回溯法子集树模板解决迷宫问题的详细内容,更多文章请关注木庄网络博客!!
相关阅读 >>
如何使用 pylint 来规范 Python 代码风格(来自ibm)_Python
Python anaconda 安装 环境变量 升级 以及特殊库安装
更多相关阅读请进入《Python》频道 >>

Python编程 从入门到实践 第2版
python入门书籍,非常畅销,超高好评,python官方公认好书。