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

    你可能感兴趣的文章
    nodejs包管理工具对比:npm、Yarn、cnpm、npx
    查看>>
    NodeJs单元测试之 API性能测试
    查看>>
    nodejs图片转换字节保存
    查看>>
    nodejs在Liunx上的部署生产方式-PM2
    查看>>
    nodejs基于art-template模板引擎生成
    查看>>
    nodejs字符与字节之间的转换
    查看>>
    NodeJs学习笔记001--npm换源
    查看>>
    NodeJs学习笔记002--npm常用命令详解
    查看>>
    nodejs学习笔记一——nodejs安装
    查看>>
    vue3+Element-plus icon图标无法显示的问题(已解决)
    查看>>
    NodeJS实现跨域的方法( 4种 )
    查看>>
    nodejs封装http请求
    查看>>
    nodejs常用组件
    查看>>
    nodejs开发公众号报错 40164,白名单配置找不到,竟然是这个原因
    查看>>
    Nodejs异步回调的处理方法总结
    查看>>
    NodeJS报错 Fatal error: ENOSPC: System limit for number of file watchers reached, watch ‘...path...‘
    查看>>
    nodejs支持ssi实现include shtml页面
    查看>>
    Nodejs教程09:实现一个带接口请求的简单服务器
    查看>>
    nodejs服务端实现post请求
    查看>>
    nodejs框架,原理,组件,核心,跟npm和vue的关系
    查看>>