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

蓝桥杯py组入门(bfs广搜)

7. 走迷宫

7.走迷宫 - 蓝桥云课

题目描述

给定一个 N×M 的网格迷宫 G。G 的每个格子要么是道路,要么是障碍物(道路用 1 表示,障碍物用 0 表示)。

已知迷宫的入口位置为 (x1​,y1​),出口位置为 (x2​,y2​)。问从入口走到出口,最少要走多少个格子。

输入描述

输入第 1 行包含两个正整数 N,M,分别表示迷宫的大小。

接下来输入一个 N×M 的矩阵。若 Gi,j​=1 表示其为道路,否则表示其为障碍物。

最后一行输入四个整数 x1​,y1​,x2​,y2​,表示入口的位置和出口的位置。

1≤N,M≤10^2,0≤Gi,j≤1,1≤x1,x2≤N,1≤y1,y2≤M。

输出描述

输出仅一行,包含一个整数表示答案。

若无法从入口到出口,则输出 −1。

输入输出样例

示例 1

5 5 
1 0 1 1 0
1 1 0 1 1 
0 1 0 1 1
1 1 1 1 1
1 0 0 0 1
1 1 5 5 

8

很标准的广搜,深搜的话会爆时间

代码 

import queue

N = 110
g = [[-1] * N for _ in range(N)]
dist = [[-1] * N for _ in range(N)]
d = [[1,0],[0,1],[-1,0],[0,-1]]

n, m = map(int,input().split())
for i in range(1, n + 1):
  g[i][1 : m + 1] = list(map(int,input().split()))
x1, y1, x2, y2 = map(int,input().split())

def bfs():
  q = queue.Queue()
  q.put([x1, y1])
  dist[x1][y1] = 0

  while not q.empty():
    x, y = q.get()

    if x == x2 and y == y2:
      return dist[x2][y2]

    for i in range(4):
      nx = x + d[i][0]
      ny = y + d[i][1]
      if nx < 1 or nx > n or ny < 1 or ny > m:
        continue
      if g[nx][ny] == 1 and dist[nx][ny] == -1:
        dist[nx][ny] = dist[x][y] + 1
        q.put([nx, ny])
  return -1

t = bfs()

print(t)

加油


http://www.kler.cn/a/379590.html

相关文章:

  • 数仓建模(五)选择数仓技术栈:Hive ClickHouse 其它
  • 手撕代码: C++实现按位序列化和反序列化
  • Spring bean的生命周期和扩展
  • 该虚拟机似乎正在使用中。 如果该虚拟机未在使用,请按“获取所有权(T)”按钮获取它的所有权。否则,请按“取消(C)”按钮以防损坏。
  • 一 rk3568 Android 11固件开发环境搭建 (docker)
  • 51c大模型~合集104
  • git入门教程4:git工作流程
  • 【ARM Linux 系统稳定性分析入门及渐进 1.2 -- Crash 工具依赖内容】
  • 软考:通信系统架构设计
  • 【django】Django REST Framework 序列化与反序列化详解
  • 07.适配器模式设计思想
  • 论文学习——A Prompt Pattern Catalog to Enhance Prompt Engineering with ChatGPT
  • Redis-数据结构和内部编码
  • Java学习Day54:初遇萍萍(权限控制)
  • 11.03学习
  • 智慧汇聚:十款企业培训工具打造学习型企业
  • PostgreSQL核心揭秘(二)-进程和内存架构
  • 深入解析缓存模式下的数据一致性问题
  • 论文学习笔记(一)
  • leetcode hot100【LeetCode 3. 无重复字符的最长子串】java实现
  • 发现一个宝藏AI解梦工具
  • 零基础Java第十三期:继承与多态(一)
  • 【算法赌场】SPFA算法
  • Android音频进阶之PCM设备创建(九十三)
  • 【WPF】MatrixTransform类
  • 【Kotlin】 基础语法笔记