如何解决在python中使用BFS算法解决UVA问题
我在 Python 中遇到以下问题:https://onlinejudge.org/index.php?option=onlinejudge&page=show_problem&problem=1594
这是我的代码:
from queue import Queue
MAX = 1001
table = [[0] * MAX for i in range(MAX)]
dist = [[0] * MAX for i in range(MAX)]
dr = [0,-1,1]
dc = [-1,1,0]
def BFS(sr,sc,fr,fc):
q = Queue()
q.put((sr,sc))
while not q.empty():
ur,uc = q.get()
for i in range(4):
rr = ur + dr[i]
cc = uc + dc[i]
if rr == fr and cc == fc:
dist[rr][cc] = dist[ur][uc] + 1
return
if rr in range(r) and cc in range(c) and table[rr][cc] != 1:
q.put((rr,cc))
dist[rr][cc] = dist[ur][uc] + 1
while True:
r,c = map(int,input().split())
if r == 0 and c == 0:
exit()
# Reset variable
for i in range(r):
for j in range(c):
table[i][j] = 0
dist[i][j] = 0
row = int(input())
for i in range(row):
b = list(map(int,input().split()))
for j in range(2,len(b)):
table[i][b[j]] = 1
sr,sc = map(int,input().split())
fr,fc = map(int,input().split())
BFS(sr,fc)
print(dist[fr][fc])
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。