- 在线时间
- 480 小时
- 最后登录
- 2026-6-1
- 注册时间
- 2023-7-11
- 听众数
- 4
- 收听数
- 0
- 能力
- 0 分
- 体力
- 7823 点
- 威望
- 0 点
- 阅读权限
- 255
- 积分
- 2934
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 1174
- 主题
- 1189
- 精华
- 0
- 分享
- 0
- 好友
- 1
该用户从未签到
 |
题目描述】
7 R( Z. \& C9 J$ z5 h! ^" ~, V( Z
给定一个 n×m 的二维整数数组,用来表示一个迷宫,数组中只包含 0 或 1,其中 0 表示可以走的路,1 表示不可通过的墙壁。最初,有一个人位于左上角 (1,1)处,已知该人每次可以向上、下、左、右任意一个方向移动一个位置。请问,该人从左上角移动至右下角 (n,m)处,至少需要移动多少次。数据保证 (1,1) 处和 (n,m) 处的数字为 0,且一定至少存在一条通路。" m* f! P0 E9 \& c. u: `
; R6 D5 u9 b0 _+ O1 d6 P: n# L【输入格式】
0 S, Q: Y( w& m* a6 d) J# r) j
% Z+ w' y& S3 M/ C 第一行包含两个整数 n 和 m。
+ H) H5 U+ I( K* G$ ~/ r' d2 W9 E
+ J8 m7 A+ y+ Z- I. O 接下来 n行,每行包含 m 个整数(0 或 1),表示完整的二维数组迷宫。
2 w+ O1 d; t9 M- i* v( W$ V" \. ]+ J4 c0 g6 u
【输出格式】
2 a2 G! t+ H, [
/ g9 e7 l, {: [+ g0 z7 _% Z. X 输出一个整数,表示从左上角移动至右下角的最少移动次数。
0 P4 n/ i4 |4 N; X- x
B: z/ a3 b0 k: C" H【数据范围】
# L+ g$ \- U# H4 n$ p+ r
/ m! {8 X+ m8 J" l' q: g9 C0 w1 Q 1≤n,m≤1008 w, C, L& ], ^% g" d0 T
5 p* h" Q, o g' t2 q
【输入样例】% p& d P, ]/ r
% Z1 q0 V. Q. ?) e: D. P: F! N
5 5
$ y! O, F7 g- a, R0 1 0 0 0
/ O* ?3 u& [! h& V0 b! M0 1 0 1 0" X% `- `: `% N7 a
0 0 0 0 0( Y/ m3 d6 G5 P) ^8 x
0 1 1 1 0
, H) ]4 I( d# t% W0 y5 R0 0 0 1 02 _" y& z$ R7 h5 T$ Q) p
【输出样例】
' J9 B" O4 n6 h* m; {4 i! J. u: X' [2 R4 }5 x( c- Y; T: O
8
; u/ E$ {4 a& i3 v A 【解题思路】
' V# r' ^+ Q& E% I2 d; k w7 r6 Y. T3 A
BFS的典中典。- from collections import *
, V: }1 K& T& [/ G8 @ - n,m = map(int,input().split())5 w( ?. Z( T! F. I5 w7 H- Y
- mp = [[0]*(m+5)]
; o& d9 _! @/ h) S: i\" N - for i in range(n):9 y: v z* F% @
- mp.append([0]+list(map(int,input().split())))
3 E. d8 L F) L3 z\" R: r2 m; g\" q: E - dir = [(1,0),(-1,0),(0,1),(0,-1)]. s7 L\" p7 U6 _/ p
- st = [[0]*(m+5) for _ in range(n+5)]\" u\" F- N0 ^+ U
- def bfs():
2 K0 {$ ^3 S5 V2 _+ q7 Z - q = deque()
9 h8 {7 w# _4 g8 I - q.append([1,1,0])- d% x# ^2 [) d7 e' A
- st[1][1]=10 Y9 _+ Q- s% B: g- p% W$ o' M- p
- while q:7 n2 Z\" W B9 c* Q C. |& [\" M7 f! r* M
- tx,ty,step = q.popleft()
; g7 t! D: O R, f& b - if tx==n and ty==m:
- ^; x8 h5 O0 a - print(step)
]& ^4 f% t, A; |0 p0 h) _9 @ - return8 d2 O. Y' Z4 W z
- for x_,y_ in dir:
0 q i/ ^. C4 q! B - nx,ny = tx+x_,ty+y_0 M) B- Q8 V$ i0 c8 Q$ X
- if nx<1 or nx>n or ny<1 or ny>m:continue
1 K7 [0 n& z- i+ p5 b\" r' S - if mp[nx][ny]==1 or st[nx][ny]:continue
+ }( k0 o6 u f! p - q.append( [nx,ny,step+1] )
! Z9 g! I0 o( J) l1 d2 @ - st[nx][ny]=1
# P( n; f; |5 Q' \) Q& N. i4 {8 a# Z - bfs()
复制代码 + t% I, ^' S* O) y- H$ K( w
|
zan
|