- 在线时间
- 480 小时
- 最后登录
- 2026-6-1
- 注册时间
- 2023-7-11
- 听众数
- 4
- 收听数
- 0
- 能力
- 0 分
- 体力
- 7823 点
- 威望
- 0 点
- 阅读权限
- 255
- 积分
- 2934
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 1174
- 主题
- 1189
- 精华
- 0
- 分享
- 0
- 好友
- 1
该用户从未签到
 |
题目描述】2 h6 {( A* N( j& `' v0 O0 s3 }) e
1 \; T S7 m4 e5 c 给定一个 n×m 的二维整数数组,用来表示一个迷宫,数组中只包含 0 或 1,其中 0 表示可以走的路,1 表示不可通过的墙壁。最初,有一个人位于左上角 (1,1)处,已知该人每次可以向上、下、左、右任意一个方向移动一个位置。请问,该人从左上角移动至右下角 (n,m)处,至少需要移动多少次。数据保证 (1,1) 处和 (n,m) 处的数字为 0,且一定至少存在一条通路。% y/ y# e$ Y$ D u5 t( z
) q: ]+ \/ @% f5 D【输入格式】
' n" S* [0 B% f. g: H. N+ G* ]0 A
) t! S$ F' r8 `9 |+ L4 n' { 第一行包含两个整数 n 和 m。# o6 @( N/ G0 K7 A0 ?4 W; [3 m' v
$ n* Q" J3 \! K# n1 E+ O7 q 接下来 n行,每行包含 m 个整数(0 或 1),表示完整的二维数组迷宫。$ k( P1 }8 G2 T$ l* I6 l- H
, s) `6 O j" u; V2 b# A7 V4 }/ Y
【输出格式】
, [! V& e' n7 P" m3 H7 I: D: B; M
6 ]' ]) u# \% C( N: H- l 输出一个整数,表示从左上角移动至右下角的最少移动次数。
: `7 D" m1 N+ e% C
. c/ g5 `+ m6 f+ [【数据范围】" ~4 z! B( t; g
5 e+ @. ]- b! m, {) H# u/ r 1≤n,m≤100
1 C% N0 V. Q6 U2 \7 L% R$ j2 V% ^- r- J4 o
【输入样例】# r ]9 U: i/ C* ]) s @
0 x& l9 u v2 M2 |. a" Q0 ?: ^
5 5
& c0 W- V& m3 Y' O6 B0 1 0 0 0
+ u' {2 t5 d" V, Z0 1 0 1 0. R9 { K7 e9 S/ S# ]
0 0 0 0 0# C/ J$ T9 g& Q$ S6 i* W2 c
0 1 1 1 0+ L! {% r e7 e, B8 y
0 0 0 1 08 C2 f H! y' n' l' g
【输出样例】) A. V8 T1 v: D; B0 K* F7 q
( p: E' f- H+ i3 S4 A
8! Y/ }1 O. w1 }+ L a: a; d
【解题思路】
9 E$ @" S& Y: G% @4 O9 D, i1 ]+ X4 l, ]% Q
BFS的典中典。- from collections import *
! {% ?% w \( z+ I/ m - n,m = map(int,input().split())+ @\" w9 C% v4 E0 S. L+ G/ I$ i
- mp = [[0]*(m+5)] l/ ~( r2 M\" Z7 Y
- for i in range(n):
1 r2 i' u( R. F+ c, s3 B. T2 N: E - mp.append([0]+list(map(int,input().split())))
7 g# b d' M% @& P, K - dir = [(1,0),(-1,0),(0,1),(0,-1)]
$ Z/ l% V: N) @: S8 u1 X - st = [[0]*(m+5) for _ in range(n+5)]
R9 P i4 d( _ - def bfs():6 b6 e8 m; ~) {9 M6 o8 o
- q = deque()\" [% W1 |! D: Y1 h9 E0 w( d
- q.append([1,1,0])6 s8 ~1 m3 x& s' B( v3 ~6 i
- st[1][1]=1) N* Y# C' C6 O8 H0 M3 R; p
- while q:$ [% R8 O! l' N2 Q
- tx,ty,step = q.popleft() f3 U- R9 C6 v3 D) _/ F
- if tx==n and ty==m:
5 v) A, G* |6 N# u' v1 O - print(step)
8 i, U5 @5 N8 b0 G\" [ - return' C2 ^- `( ]2 u' N5 a% q6 M0 s\" @
- for x_,y_ in dir:) E1 k; c, Z1 ~1 W
- nx,ny = tx+x_,ty+y_
+ i- j: g3 B\" j3 X\" ^3 J - if nx<1 or nx>n or ny<1 or ny>m:continue
# N, `, \- l/ E - if mp[nx][ny]==1 or st[nx][ny]:continue
( T: K# Y; H\" g\" [3 U: d; d - q.append( [nx,ny,step+1] )
) N+ U6 A\" c1 g7 c - st[nx][ny]=1
. V4 F\" o& L6 S9 C) u' t/ U - bfs()
复制代码
3 n# |- x# b& P$ a |
zan
|