博客
关于我
迷宫(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/

    你可能感兴趣的文章
    oracle优化器analyzed,Oracle 学习之 性能优化(十三) 索引
    查看>>
    Oracle修改字段类型
    查看>>
    oracle典型安装失败,安装oracle 10失败
    查看>>
    Oracle内存结构详解(四)--Oracle SGA其他组成部分
    查看>>
    Oracle分析函数之LEAD和LAG
    查看>>
    Oracle创建database link(dblink)和同义词(synonym)
    查看>>
    oracle创建数据库的步骤
    查看>>
    Oracle发布VirtualBox 7.1稳定版!支持ARM、优化了UI、支持Wayland等
    查看>>
    Oracle命令行创建数据库
    查看>>
    Oracle和SQL server的数据类型比较
    查看>>
    oracle基础 管理索引
    查看>>
    oracle用户改名
    查看>>
    Oracle用游标删除重复数据
    查看>>
    Oracle的聚合函数group by结合CUBE和ROLLUP的使用
    查看>>
    Oracle监听配置、数据库实例配置等
    查看>>
    Oracle系列:安装Oracle RAC数据库(二)
    查看>>
    oracle系统 介绍,ORACLE数据库管理系统介绍
    查看>>
    oracle获取数据库表、字段、注释、约束等
    查看>>
    oracle表空间查询维护命令大全之三(暂时表空间)史上最全
    查看>>
    oracle表访问方式
    查看>>