当前位置: 首页 > news >正文

题解:洛谷 P3916 图的遍历

【题目来源】

洛谷:P3916 图的遍历 - 洛谷

【题目描述】

给出 \(N\) 个点,\(M\) 条边的有向图,对于每个点 \(v\),求 \(A(v)\) 表示从点 \(v\) 出发,能到达的编号最大的点。

【输入】

\(1\)\(2\) 个整数 \(N,M\),表示点数和边数。

接下来 \(M\) 行,每行 \(2\) 个整数 \(U_i,V_i\),表示边 \((U_i,V_i)\)。点用 \(1,2,\dots,N\) 编号。

【输出】

一行 \(N\) 个整数 \(A(1),A(2),\dots,A(N)\)

【输入样例】

4 3
1 2
2 4
4 3

【输出样例】

4 4 3 4

【解题思路】

image

image

【算法标签】

《洛谷 P3916 图的遍历》 #搜索# #图论# #图论建模# #强连通分量#

【代码详解】

#include <bits/stdc++.h>
using namespace std;
struct d {  // 定义每个点的结构体vector<int> cdd;  // 每个点的邻接点int ad;  // 到达的编号最大的点
};
int main()
{int n, m, ls1, ls2, nls;queue<d> que;cin >> n >> m;  // 输入n和md ds[n+1];  // 定义结构体数组for (int i=1; i<=n; i++) {  // for循环遍历所有点ds[i].ad = i;  // 每个点初始可到达的编号最大的点都是自己}for (int i=0; i<m; i++) {  // for循环遍历m条边cin >> ls1 >> ls2;  // 输入起始点和终止点ds[ls2].cdd.push_back(ls1);  // 反向存储,终止点可以到达的起始点}for (int i=n; i>0; i--) {  // 从最后一个点开始往前遍历que.push(ds[i]);  // 将这个点放入队列中while (que.size()) {  // 当队列不为空for (int j=0; j<que.front().cdd.size(); j++) {  // 遍历该点可到达的所有点nls = que.front().cdd[j];  // 获得i的邻接点,赋值给nlsif (ds[nls].ad == nls && ds[nls].ad < i) {  // 如果该邻接点nls的可到达编号最大的点为自己(没有修改过),且小于当前点i(即存在比i小的,且nls可以到达的点)ds[nls].ad = i;  // 则该点的邻接点nls的可到达的编号最大的点就是ique.push(ds[nls]);  // 将该点的邻接点压入队列}}que.pop();}}for (int i=1; i<=n; i++) {cout << ds[i].ad << " ";}cout << endl;return 0;
}

【运行结果】

4 3
1 2
2 4
4 3
4 4 3 4
http://www.jsqmd.com/news/392391/

相关文章:

  • 【硬盘】个人数据备份的各种方式##37
  • 题解:洛谷 P5318 【深基18.例3】查找文献
  • 题解:洛谷 P4017 最大食物链计数
  • 题解:洛谷 P1113 杂务
  • 别只会用 getData!Watcher 注册源码流程全拆解
  • Java线程解析:5种线程创建方法及应用场景 - 指南
  • 题解:洛谷 P2814 家谱
  • 题解:洛谷 P3879 [TJOI2010] 阅读理解
  • 2024 年 09 月 二级真题(1)--数位之和
  • 2026年龙岩连城长汀红白喜事鼓吹铜管乐队演出推荐:客家非遗与市场化服务的平衡之选 - 小白条111
  • 题解:洛谷 P4305 [JLOI2011] 不重复数字
  • 12:内核ROP与提权技术
  • 13:现代内核保护机制与绕过技术
  • 14:跨架构内核漏洞利用差异
  • 超市在线销售与分析|基于Python + Django超市在线销售与分析系统(源码+数据库+文档)
  • AI知识图谱构建:企业智能搜索的底层架构
  • 大数据领域数据中台的教育培训机构数据分析
  • 一天一个开源项目(第26篇):ZeroClaw - 零开销、全 Rust 的自主 AI 助手基础设施,与 OpenClaw 的关系与对比
  • OpenClaw(Clawdbot)部署指南:2026年天翼云部署快速上手
  • 彼得林奇的“家庭作业“投资法
  • 实用指南:Elasticsearch:监控 LLM 推理和 Agent Builder 使用 OpenRouter
  • AI提示系统反馈机制设计:如何解决“反馈噪音”问题?
  • 企业H5站点升级PWA (一)
  • 456348568
  • 75757
  • MongoDB备份策略:大数据场景下全量+增量备份的实现与恢复测试
  • AI训练算力利用率低?架构师的4个算力优化+调度方案
  • OpenClaw(Clawdbot):2026阿里云部署教程,掌握技巧超容易
  • 企业H5站点升级PWA (三)
  • OpenClaw(原Clawdbot)2026阿里云部署:手把手教学全记录