博客
关于我
迷宫(bfs)
阅读量:520 次
发布时间:2019-03-07

本文共 1794 字,大约阅读时间需要 5 分钟。

为了解决这个问题,我们需要在一个网格迷宫中找到所有可以到达的格子。每次移动可以向上下左右移动一格,但向左移动的次数不能超过 x 次,向右移动的次数不能超过 y 次。我们可以使用广度优先搜索(BFS)来解决这个问题。

方法思路

  • 问题分析:我们需要从起点出发,找到所有可以到达的格子。每次移动可以向上、下、左、右移动一格,但左和右移动的次数分别不能超过 x 和 y 次。
  • 转换问题:将问题转化为检查每个格子是否满足左移次数不超过 x 次,右移次数不超过 y 次,并且存在一条路径连接起点和该格子。
  • BFS 算法:使用 BFS 进行搜索,只处理满足上述条件的格子。每次扩展四个方向的邻居,检查是否越界、是否为障碍以及是否满足移动次数限制。
  • 优化:预处理每个格子是否满足左移和右移次数限制,避免不必要的计算和状态扩展。
  • 解决代码

    #include 
    #include
    #include
    using namespace std;int main() { // 读取输入 int n, m; cin >> n >> m; int r, c; cin >> r >> c; r--; c--; // 转为0-based索引 int x, y; cin >> x >> y; char mp[n][m]; for (int i = 0; i < n; ++i) { string s; cin >> s; for (int j = 0; j < m; ++j) { mp[i][j] = s[j]; } } // 初始化访问数组和队列 bool visited[n][m]; queue
    > q; visited[r][c] = true; q.push(make_pair(r, c)); int sum = 1; // 起点计数 // 四个方向:上下左右 int dirs[4][2] = {{-1, 0}, {1, 0}, {0, -1}, {0, 1}}; while (!q.empty()) { pair
    current = q.front(); q.pop(); int i = current.first, j = current.second; for (int d = 0; d < 4; ++d) { int ni = i + dirs[d][0]; int nj = j + dirs[d][1]; // 检查是否越界 if (ni < 0 || ni >= n || nj < 0 || nj >= m) { continue; } // 检查是否是障碍 if (mp[ni][nj] != '.') { continue; } // 计算max_left和max_right int dr = ni - r; int dc = nj - c; int max_left = max(-dr, 0); int max_right = max(dc, 0); if (max_left <= x && max_right <= y) { if (!visited[ni][nj]) { visited[ni][nj] = true; sum++; q.push(make_pair(ni, nj)); } } } } cout << sum << endl; return 0;}

    代码解释

  • 输入处理:读取迷宫的大小、起点、左移和右移次数限制,以及迷宫格子的布局。
  • 初始化:将起点标记为已访问,并将其加入队列。
  • BFS 过程:从队列中取出当前位置,检查四个方向的邻居。对于每个邻居,检查是否越界、是否为障碍以及是否满足移动次数限制。如果满足条件且未被访问过,标记为已访问并加入队列。
  • 结果输出:统计并输出所有可以到达的格子数量。
  • 这种方法确保了我们高效地找到所有满足条件的格子,避免了不必要的计算和状态扩展。

    转载地址:http://iuqjz.baihongyu.com/

    你可能感兴趣的文章
    opencv特征提取1-Harris角点检测
    查看>>
    OpenCV环境搭建(一)
    查看>>
    OpenCV的视频读取
    查看>>
    openCV目标识别 目标跟踪 YOLO5深度学习 Python 计算机视觉 计算机毕业设计 源码下载
    查看>>
    opencv笔记(1):图像缩放
    查看>>
    opencv笔记(二十四)——得到轮廓之后找到凸包convex hull
    查看>>
    OpenCV计算点到直线的距离 数学法
    查看>>
    Opencv识别图中人脸
    查看>>
    OpenCV读写avi、mpeg文件
    查看>>
    opencv里用calcCovarMatrix计算协方差矩阵
    查看>>
    OpenCV错误:在setSize中断言失败(s&>;=0)-尝试将图像放置在网络摄像头提要上时
    查看>>
    opencv面向对象设计初探
    查看>>
    OpenCV(1)读写图像
    查看>>
    OpenCV:不规则形状区域中每种颜色的像素数?
    查看>>
    OpenCV:概念、历史、应用场景示例、核心模块、安装配置
    查看>>
    OpenDaylight融合OpenStack架构分析
    查看>>
    OpenERP ORM 对象方法列表
    查看>>
    openEuler Summit 2022 成功举行,开启全场景创新新时代
    查看>>
    openEuler 正式开放:推动计算多样化时代的到来
    查看>>
    OpenEuler23.03欧拉系统_安装瀚高数据库企业版6.0.4_openeuler切换root用户_su:拒绝权限_passwd: 鉴定令牌操作错误---国产瀚高数据库工作笔记001
    查看>>