博客
关于我
L3-008 喊山 (30分) C++ BFS题解
阅读量:379 次
发布时间:2019-03-05

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

为了解决这个问题,我们需要找到从给定的山头发出的呼喊能够传达到的最远山头。每个山头最多有两个能听到它的邻近山头。我们可以使用广度优先搜索(BFS)来解决这个问题,因为它能够有效地处理层次遍历,找到最远的节点。

方法思路

  • 图的构建:使用邻接表来表示山头之间的关系。每个山头的编号从1到n。
  • 广度优先搜索(BFS):从查询的山头出发,进行BFS遍历,记录每个节点的层数(距离查询山头的层次)。
  • 记录最远节点:在BFS过程中,记录最大的层数和对应的最小节点编号。如果有多个节点在同一层次,选择编号最小的那个。
  • 处理查询:对于每个查询,执行BFS并输出结果。
  • 解决代码

    #include 
    #include
    #include
    using namespace std;int main() { int n, m, k; cin >> n >> m >> k; vector
    > adj(n + 1); for (int i = 0; i < m; ++i) { int a, b; cin >> a >> b; adj[a].push_back(b); adj[b].push_back(a); } for (int i = 0; i < k; ++i) { int q; cin >> q; vector
    visited(n + 1, false); vector
    distance(n + 1, 0); queue
    q_bfs; q_bfs.push(q); visited[q] = true; distance[q] = 0; int max_dist = 0; int min_node = q; while (!q_bfs.empty()) { int u = q_bfs.front(); q_bfs.pop(); for (int v : adj[u]) { if (!visited[v]) { visited[v] = true; distance[v] = distance[u] + 1; if (distance[v] > max_dist) { max_dist = distance[v]; min_node = v; } else if (distance[v] == max_dist) { if (v < min_node) { min_node = v; } } q_bfs.push(v); } } } if (max_dist == 0) { cout << 0 << endl; } else { cout << min_node << endl; } } return 0;}

    代码解释

  • 输入读取:首先读取输入数据,构建邻接表adj来表示山头之间的关系。
  • BFS初始化:对于每个查询的山头,初始化访问数组visited和层数数组distance,并将查询山头入队。
  • BFS遍历:从查询山头出发,进行BFS遍历,记录每个节点的层数,并更新最远层数和对应的最小节点。
  • 结果输出:根据BFS结果,输出最远节点。如果查询山头没有连接任何节点,输出0。
  • 这种方法确保了我们能够高效地找到从给定山头发出的呼喊能够传达到的最远山头。

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

    你可能感兴趣的文章
    Nginx log文件写入失败?log文件权限设置问题
    查看>>
    Nginx Lua install
    查看>>
    nginx net::ERR_ABORTED 403 (Forbidden)
    查看>>
    Nginx SSL 性能调优
    查看>>
    Nginx SSL私有证书自签,且反代80端口
    查看>>
    Nginx upstream性能优化
    查看>>
    Nginx 中解决跨域问题
    查看>>
    nginx 代理解决跨域
    查看>>
    Nginx 做负载均衡的几种轮询策略分析
    查看>>
    Nginx 入门,一篇搞定!
    查看>>
    Nginx 利用代理转发请求示例
    查看>>
    Nginx 动静分离与负载均衡的实现
    查看>>
    Nginx 反向代理 MinIO 及 ruoyi-vue-pro 配置 MinIO 详解
    查看>>
    nginx 反向代理 转发请求时,有时好有时没反应,产生原因及解决
    查看>>
    Nginx 反向代理+负载均衡
    查看>>
    Nginx 反向代理解决跨域问题
    查看>>
    Nginx 反向代理配置去除前缀
    查看>>
    nginx 后端获取真实ip
    查看>>
    Nginx 多端口配置和访问异常问题的排查与优化
    查看>>
    Nginx 如何代理转发传递真实 ip 地址?
    查看>>