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

    你可能感兴趣的文章
    Netty工作笔记0027---NIO 网络编程应用--群聊系统2--服务器编写2
    查看>>
    Netty工作笔记0050---Netty核心模块1
    查看>>
    Netty工作笔记0060---Tcp长连接和短连接_Http长连接和短连接_UDP长连接和短连接
    查看>>
    Netty工作笔记0077---handler链调用机制实例4
    查看>>
    Netty工作笔记0084---通过自定义协议解决粘包拆包问题2
    查看>>
    Netty常见组件二
    查看>>
    netty底层源码探究:启动流程;EventLoop中的selector、线程、任务队列;监听处理accept、read事件流程;
    查看>>
    Netty核心模块组件
    查看>>
    Netty框架的服务端开发中创建EventLoopGroup对象时线程数量源码解析
    查看>>
    Netty源码—2.Reactor线程模型一
    查看>>
    Netty源码—4.客户端接入流程一
    查看>>
    Netty源码—4.客户端接入流程二
    查看>>
    Netty源码—5.Pipeline和Handler一
    查看>>
    Netty源码—6.ByteBuf原理二
    查看>>
    Netty源码—7.ByteBuf原理三
    查看>>
    Netty源码—7.ByteBuf原理四
    查看>>
    Netty源码—8.编解码原理二
    查看>>
    Netty源码解读
    查看>>
    Netty的Socket编程详解-搭建服务端与客户端并进行数据传输
    查看>>
    Netty相关
    查看>>