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

P2746题解

问题:
本题描述了一个有向图模型:
每个学校是一个节点
学校间的分享关系构成有向边(如果 a 分享给 b,则存在 a→b 的边)
需要解决两个独立的问题:
1.至少需要向几个学校发放软件,才能让所有学校都获得软件
相当于找到最少数量的起点,使得从这些起点出发可以到达所有节点
2.至少需要添加多少条边,使得整个图变成强连通图
使得无论从哪个学校发放软件,所有学校都能获得软件
思路:
使用 Tarjan 算法缩点后:
对于问题1:
缩点后得到 DAG(有向无环图)
需要发放软件的学校数量 = DAG 中入度为 0 的强连通分量数量
因为入度为 0 的点没有其他点能到达它,必须作为起点
对于问题2:
需要使 DAG 变成强连通图
最少需要添加的边数=max(入度为0的点数, 出度为0的点数)
特殊情况:如果整个图已经是一个强连通分量,答案为 0
算法:
使用 Tarjan 算法求强连通分量
对每个未访问的节点进行 DFS
维护 dfn(访问顺序)和 low(能回溯到的最早节点)
当 low[u] == dfn[u] 时,找到一个强连通分量
缩点并统计度数
对原图的每条边,如果两端点在不同分量,则在缩点后的图中添加边
统计每个分量的入度和出度
计算答案
问题1:入度为0的分量个数
问题2:如果只有一个分量:0
否则:max(入度为0的个数, 出度为0的个数)
代码:
#include<bits/stdc++.h>
using namespace std;
const int N=110;
int n,tot,tp,cl;
vector<int>g[N];
int dfn[N],low[N],st[N],col[N],sz[N];
int ind[N],oud[N];
void tarjan(int u){
dfn[u]=low[u]=++tot;
st[++tp]=u;
for(int v:g[u]){
if(!dfn[v]){
tarjan(v);
low[u]=min(low[u],low[v]);
}
else if(!col[v])low[u]=min(low[u],dfn[v]);
}
if(low[u]==dfn[u]){
col[u]=++cl;
while(st[tp]!=u){
col[st[tp]]=cl;
tp--;
}
tp--;
}
}
int main(){
cin>>n;
for(int i=1;i<=n;i++){
int x;
cin>>x;
while(x){
g[i].push_back(x);
cin>>x;
}
}
for(int i=1;i<=n;i++)if(!dfn[i])tarjan(i);
for(int u=1;u<=n;u++){
for(int v:g[u]){
if(col[u]!=col[v]){
ind[col[v]]++;
oud[col[u]]++;
}
}
}
int ans1=0,ans2=0;
for(int i=1;i<=cl;i++){
if(!ind[i])ans1++;
if(!oud[i])ans2++;
}
cout<<ans1<<endl;
if(cl==1)cout<<0;
else cout<<max(ans1,ans2);
return 0;
}

http://www.rkmt.cn/news/93968.html

相关文章:

  • 企业级AI路由网关:解锁多模型智能调度的未来
  • LOOT完整使用指南:游戏模组加载顺序优化利器
  • 【URP】Unity[后处理]色差ChromaticAberration
  • Aurora UI 安装配置终极指南
  • SoFixer:专业修复内存dump的So文件工具完全指南
  • 完整教程:深度学习:Mini-Batch 梯度下降(Mini-Batch Gradient Descent)
  • 少儿编程考试路径规划:考级与竞赛时间如何平衡?
  • UG NX工程制图时,常见会出现哪些异常问题
  • 【渲染优化】动态调整虚拟列表刷新率:让代码学会“偷懒“
  • 《深入 Ascend C 编程:从零构建高性能 AI 算子(上)—— 基础架构与矩阵乘法实战》
  • IIoT 内容接口契约化工具JSON、OPC UA和Sparkplug B 优缺点对比分析
  • NCT与GESP哪个更好?线上监考与线下考点的便利性对比
  • 20251213
  • 【Java毕设全套源码+文档】基于Java的横向课题信息管理系统的设计与实现(丰富项目+远程调试+讲解+定制)
  • 戴森球计划FactoryBluePrints终极指南:3步打造高效星际工厂
  • AI写论文工具排行榜:9个优选方案,覆盖开题到终稿全流程
  • windows著名漏洞——Zerologon(零登录)
  • 20251213给飞凌OK3588-C开发板适配Rockchip原厂的Buildroot【linux-6.1】系统时适配CTP触摸屏FT5X06
  • 快速排序:10分钟掌握高效算法精髓
  • 北京雅思培训机构综合评测与选择指南 - 品牌测评鉴赏家
  • 机器学习:基于python租房推荐系统 预测算法 协同过滤推荐算法 房源信息 可视化 机器学习-线性回归预测模型 Flask框架(源码+文档)✅ - 详解
  • Astrofy:快速构建现代化个人作品集的免费开源模板
  • 如何快速掌握THC-Hydra:网络安全新手的完整指南
  • 路由器的5G和手机上的5G是一个意思吗?深度解析两大区别
  • 3大实战场景:深度解决.NET MAUI在Android平台的适配痛点
  • React(一):使用react-router构建导航应用
  • Android桌面控制终极方案:AYA让ADB图形界面操作变得简单快速
  • BibTeX Tidy终极指南:快速整理和格式化你的学术引用文件
  • Flutter国际化终极指南:Easy Localization完整教程
  • 实战进阶:软件架构设计模式深度解析与应用指南