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

    你可能感兴趣的文章
    PHP 统计数据功能 有感
    查看>>
    SpringBoot处理JSON数据
    查看>>
    Redis使用基本套路
    查看>>
    php 解决项目中多个自动加载冲突问题
    查看>>
    PHP 设置调试工具XDebug PHPStorm IDE
    查看>>
    php 身份证号检测
    查看>>
    PHP 输入输出流合集
    查看>>
    PHP 过滤器(Filter)
    查看>>
    PHP 面向对象 final类与final方法
    查看>>
    php--防止sql注入的方法
    查看>>
    php-cgi耗尽报502错误
    查看>>
    php-cgi(fpm-cgi) 进程 CPU 100% 与 file_get_content...
    查看>>
    PHP-GD库-分类整理
    查看>>
    php-laravel框架用户验证(Auth)模块解析(三)登录模块
    查看>>
    php-laravel框架用户验证(Auth)模块解析(四)忘记密码
    查看>>
    php-redis中文参考手册_Ping_echo_set_get_setex_psetex_...
    查看>>
    php-兔子问题,斐波那契数列
    查看>>
    php-有序数组合并后仍有序
    查看>>
    Redis以及Redis的php扩展安装
    查看>>
    PHP-算法-最少比较次数获取最大值最小值
    查看>>