鱼C论坛

 找回密码
 立即注册
查看: 3835|回复: 1

迷宫(C语言)

[复制链接]
发表于 2022-5-30 22:01:30 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
在迷宫中,只能从一个方格走到相邻的上、下、左、右四个方向之一。

image.png

找到一条从起点到终点的迷宫路径,并将路径输出。如果从起点到终点没有路径,则输出NO PASS!

注:所有迷宫的起点为左上角,终点为右下角。

【输入形式】依次输入n行由0和1构成的字符串,每行字符串长度相同,输入空串结束,其中1表示围墙,0表示可行路径。
【输出形式】如果起点到终点有路,则依次输出由L、R、D、U组成的路径字符串;否则输出NO PASS!。
【样例输入】
0111111
0011101
1001101
0011001
1000111
1110000
【样例输出】
DRDDDRRDRRR
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2022-5-31 09:33:56 From FishC Mobile | 显示全部楼层
兄弟,其实题目不难,只是用 C 写比较麻烦(C 是面向过程语言)。因为太麻烦,我就不写 C 了。我写了 Python 给你参考,希望对你有帮助
  1. n = int(input())
  2. arr = [input() for _ in range(n)]
  3. arr = [[int(num) for num in row] for row in arr]

  4. def foo(arr, r = 0, c = 0, s = ""):
  5.         if r == len(arr) - 1 and c == len(arr[0]) - 1:
  6.                 print(s)
  7.                 return
  8.         elif r == len(arr) or c == len(arr[0]):
  9.                 return
  10.         elif r < 0 or c < 0:
  11.                 return
  12.         if arr[r][c]:
  13.                 return
  14.         else:
  15.                 arr[r][c] = 1
  16.         # go down
  17.         foo(arr[::], r + 1, c, s + 'D')
  18.        
  19.         # go right
  20.         foo(arr[::], r, c + 1, s + 'R')
  21.        
  22.         # go up
  23.         foo(arr[::], r - 1, c, s + 'U')
  24.                
  25.         # go left
  26.         foo(arr[::], r, c - 1, s + 'L')

  27. foo(arr)
复制代码
  1. 6
  2. 0111111
  3. 0011101
  4. 1001101
  5. 0011001
  6. 1000111
  7. 1110000
  8. DRDDDRRDRRR
复制代码

小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-24 01:28

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表