当前位置: 首页 > news >正文

笔试题(十三):走迷宫

# 描述
# 定义一个二维数组 N*M ,如 5 × 5 数组下所示:
# int maze[5][5] = {
# 0, 1, 0, 0, 0,
# 0, 1, 1, 1, 0,
# 0, 0, 0, 0, 0,
# 0, 1, 1, 1, 0,
# 0, 0, 0, 1, 0,};
# 它表示一个迷宫,其中的1表示墙壁,0表示可以走的路,只能横着走或竖着走,不能斜着走,要求编程序找出从左上角到右下角的路线。入口点为[0,0],既第一格是可以走的路。
# 数据范围: 2≤n,m≤10  , 输入的内容只包含 0≤val≤1
# 输入描述:
# 输入两个整数,分别表示二维数组的行数,列数。再输入相应的数组,其中的1表示墙壁,0表示可以走的路。数据保证有唯一解,不考虑有多解的情况,即迷宫只有一条通道。
# 输出描述:
# 左上角到右下角的最短路径,格式如样例所示。
# 示例1
# 输入:
# 5 5
# 0 1 0 0 0
# 0 1 1 1 0
# 0 0 0 0 0
# 0 1 1 1 0
# 0 0 0 1 0
# 输出:
# (0,0)
# (1,0)
# (2,0)
# (2,1)
# (2,2)
# (2,3)
# (2,4)
# (3,4)
# (4,4)
def func(i, j, pos=[(0, 0)]):# 方法1if i == m - 1 and j == n - 1:for p in pos:print(p)return 1if j + 1 < n and a[i][j + 1] == 0:  # 向右if (i, j + 1) not in pos:func(i, j + 1, pos + [(i, j + 1)])if j - 1 > 0 and a[i][j - 1] == 0:  # 向左if (i, j - 1) not in pos:func(i, j - 1, pos + [(i, j - 1)])if i + 1 < m and a[i + 1][j] == 0:  # 向下if (i + 1, j) not in pos:func(i + 1, j, pos + [(i + 1, j)])if i - 1 > 0 and a[i - 1][j] == 0:  # 向上if (i - 1, j) not in pos:func(i - 1, j, pos + [(i - 1, j)])def dfs(i, j):# 方法2# 用dx和dy分别来表示:向左, 向右, 向上, 向下dx = [0, 0, -1, 1]dy = [-1, 1, 0, 0]if i == m - 1 and j == n - 1:for pos in route:print('(' + str(pos[0]) + ',' + str(pos[1]) + ')')returnfor k in range(4):x = i + dx[k]y = j + dy[k]if 0 <= x < m and 0 <= y < n and map1[x][y] == 0:map1[x][y] = 1route.append((x, y))dfs(x, y)# 如果我们无法到达指定终点,则需要沿原路返回,再把标记过的路去掉:map[x][y]=0,route.pop(),# 直到到达当初的分岔路口,进入下一次选择。map1[x][y] = 0route.pop()else:returnif __name__ == '__main__':m = 5n = 5a = [[0, 0, 0, 0, 1],[0, 1, 1, 0, 0],[0, 1, 0, 0, 1],[0, 0, 1, 0, 0],[0, 1, 0, 1, 0]]func(0, 0)map1 = a.copy()route = [(0, 0)]map1[0][0] = 1dfs(0, 0)
http://www.lryc.cn/news/9859.html

相关文章:

  • Gradle相关的知识学习
  • SpringMVC的工作原理
  • 问卷数据分析流程
  • 【观察】Solidigm P44 Pro SSD评测:原厂品质+软硬兼施=性能怪兽
  • String对象的创建和比较
  • 09 OpenCV图形检测
  • 解密Teradata与中国市场“分手”背后的原因!国产数据库能填补空白吗?
  • Bernstein-Vazirani算法
  • 华为OD机试 - 相对开音节 | 备考思路,刷题要点,答疑 【新解法】
  • MyBatis
  • 良好的作息表
  • 【郭东白架构课 模块一:生存法则】01|模块导学:是什么在影响架构活动的成败?
  • webshell免杀之函数与变量玩法
  • 【新解法】华为OD机试 - 去重求和 | 备考思路,刷题要点,答疑,od Base 提供
  • MySQL 服务正在启动.MySQL 服务无法启动.服务没有报告任何错误。请键入 NET HELPMSG 3534 以获得更多的帮助。总结较全 (已解决)
  • 【数据结构与算法】数组2:双指针法 二分法(螺旋矩阵)
  • librtmp优化
  • 数据结构与算法(二):线性表
  • IOS安全区域适配
  • 在Java 中 利用Milo通信库,实现OPCUA客户端,并生成证书
  • 三分钟学会用Vim
  • 编译链接实战(8)认识elf文件格式
  • 新手小白如何入门黑客技术?
  • 【java】Spring Boot --深入SpringBoot注解原理及使用
  • 一文掌握如何对项目进行诊断?【步骤方法和工具】
  • 系统分析师真题2020试卷相关概念二
  • <<Java开发环境配置>>5-MySQL安装教程(绿色版)
  • 空间复杂度与时间复杂度
  • javaEE 初阶 — 延迟应答与捎带应答
  • Twitter账号老被封?一文教会你怎么养号