题目大意:给定一个 N 个点,M 条边的有向图,第一问求至少从多少个点出发才能遍历整个有向图,第二问求至少在这个有向图的基础上加多少条边才能使得该无向图强连通。

题解:先进行 Tarjan 缩点,得到一个 DAG。对于这个 DAG 来说,第一问显然是入度为 0 点的个数。第二问中的每条新边均应该是在出度为 0 点和入度为 0 点之间添加,因此答案是入度为 0 的点的个数和出度为 0 点的个数的最大值。另外,若只有一个强联通分量的话,需要特判。

代码如下

  1. #include <bits/stdc++.h>
  2. using namespace std;
  3. const int maxv=110;
  4. const int maxe=1e4+10;
  5. inline int read(){
  6. int x=0,f=1;char ch;
  7. do{ch=getchar();if(ch=='-')f=-1;}while(!isdigit(ch));
  8. do{x=x*10+ch-'0';ch=getchar();}while(isdigit(ch));
  9. return f*x;
  10. }
  11. struct node{
  12. int nxt,to;
  13. }e[maxe];
  14. int tot=1,head[maxv];
  15. inline void add_edge(int from,int to){
  16. e[++tot]=node{head[from],to},head[from]=tot;
  17. }
  18. int n;
  19. int dfs_clk,low[maxv],dfn[maxv],stk[maxv],top,in[maxv];
  20. int scc,cor[maxv];
  21. vector<int> G[maxv];
  22. int indeg[maxv],outdeg[maxv],ans1,ans2;
  23. void tarjan(int u){
  24. dfn[u]=low[u]=++dfs_clk;
  25. stk[++top]=u,in[u]=1;
  26. for(int i=head[u];i;i=e[i].nxt){
  27. int v=e[i].to;
  28. if(!dfn[v])tarjan(v),low[u]=min(low[u],low[v]);
  29. else if(in[v])low[u]=min(low[u],dfn[v]);
  30. }
  31. if(low[u]==dfn[u]){
  32. ++scc;int v;
  33. do{
  34. v=stk[top--],in[v]=0;
  35. cor[v]=scc;
  36. }while(u!=v);
  37. }
  38. }
  39. void read_and_parse(){
  40. n=read();
  41. for(int i=1,to;i<=n;i++)while(to=read())add_edge(i,to);
  42. }
  43. void solve(){
  44. for(int i=1;i<=n;i++)if(!dfn[i])tarjan(i);
  45. for(int u=1;u<=n;u++)
  46. for(int i=head[u];i;i=e[i].nxt){
  47. int v=e[i].to;
  48. if(cor[v]==cor[u])continue;
  49. G[cor[u]].push_back(cor[v]),++indeg[cor[v]],++outdeg[cor[u]];
  50. }
  51. for(int i=1;i<=scc;i++){
  52. if(!indeg[i])++ans1;
  53. if(!outdeg[i])++ans2;
  54. }
  55. ans2=scc==1?0:max(ans2,ans1);
  56. printf("%d\n%d\n",ans1,ans2);
  57. }
  58. int main(){
  59. read_and_parse();
  60. solve();
  61. return 0;
  62. }

【洛谷P2746】Network of Schools的更多相关文章

  1. POJ1236或洛谷2746或洛谷2812 Network of Schools

    POJ原题链接 洛谷2746原题链接 洛谷2812(加强版)原题链接 显然在强连通分量里的所有学校都能通过网络得到软件,所以我们可以用\(tarjan\)求出强连通分量并缩点,统计缩点后每个点的入度和 ...

  2. 洛谷 P2746 [USACO5.3]校园网Network of Schools 解题报告

    P2746 [USACO5.3]校园网Network of Schools 题目描述 一些学校连入一个电脑网络.那些学校已订立了协议:每个学校都会给其它的一些学校分发软件(称作"接受学校&q ...

  3. 洛谷 P2746 [USACO5.3]校园网Network of Schools (Tarjan,SCC缩点,DAG性质)

    P2746 [USACO5.3]校园网Network of Schools https://www.luogu.org/problem/P2746 题目描述 一些学校连入一个电脑网络.那些学校已订立了 ...

  4. 【洛谷P2746】[USACO5.3]校园网Network of Schools

    校园网Network of Schools 第一问:Tarjan缩点,搞出每一个连通块,入度为零的连通块是需要必须接受新软件副本的,统计数量即可 第二问:要让整个图构成一个环,显然要将入度为零点和出度 ...

  5. 洛谷P2746 [USACO5.3]校园网Network of Schools

    题目描述 一些学校连入一个电脑网络.那些学校已订立了协议:每个学校都会给其它的一些学校分发软件(称作“接受学校”).注意即使 B 在 A 学校的分发列表中, A 也不一定在 B 学校的列表中. 你要写 ...

  6. 洛谷P2746 校园网Network of Schools

    题目描述 一些学校连入一个电脑网络.那些学校已订立了协议:每个学校都会给其它的一些学校分发软件(称作"接受学校").注意即使 \(B\) 在 \(A\) 学校的分发列表中, \(A ...

  7. 洛谷 P2746 [USACO5.3]校园网 Network of Schools 题解

    Tarjan 模板题 第一问就是缩点之后看有多少个入度为零的点就好了. 第二问是在缩点后将每个点的入度和出度都求出(只要有入度或出度就置为1),然后比较哪个有值的多,将多的作为答案输出.原因是由题可得 ...

  8. 洛谷 P2746 [USACO5.3]校园网Network of Schools

    题目描述 一些学校连入一个电脑网络.那些学校已订立了协议:每个学校都会给其它的一些学校分发软件(称作“接受学校”).注意即使 B 在 A 学校的分发列表中, A 也不一定在 B 学校的列表中. 你要写 ...

  9. 洛谷 P2746 [USACO5.3]校园网Network of Schools schlnet Tarjan强连通分量

    schlnet ★★★   输入文件:schlnet.in   输出文件:schlnet.out   简单对比时间限制:1 s   内存限制:128 MB 描述 一些学校连入一个电脑网络.那些学校已订 ...

随机推荐

  1. Linux 小记 — Ubuntu 自动化配置

    前言 工欲善其事,必先利其器.经过多次的重复配置 ubuntu 开发坏境,我终于决定花点时间总结一下,并将其写成一个自动化配置脚本.服务器实例:ubuntu 16.04,技术栈:shell,pytho ...

  2. 20135337——Linux实践二:模块

    一.编译&生成&测试&删除 1.编写模块代码,查看如下 gedit 1.c(编写) cat 1.c(查看) MODULE_AUTHOR("Z") MODUL ...

  3. 第二个spring, 第7天

    陈志棚:成绩的统筹 李天麟:界面音乐 徐侃:代码算法 代码初步已经完成.还差最后一步整合.附上最后一张截图

  4. APP推广(预期方案)

    首先,在推广过程中有一些定的弊端:我们这个O2O平台暂时只能适用于学校局域网. 因为我们的APP才刚刚“出炉”不久,在网络上还是属于一篇空白的状态,我们想过可以在百度百科上进行相应的推广,如果有用户搜 ...

  5. CSS里Postion几个取值relative、absolute、static、fixed的区别和用法

    ---恢复内容开始--- static:静态定位,也是postion的默认值,没有定位,元素出现在正常的流中,忽略top\bottom\left\right或者z-index声明. relative: ...

  6. 原生js作用域(红宝书)

    function fn(){ ; alert(a); // 2; } alert(a);//未被定义: alert(b);//全局变量:b=2: ; function fn1(){ ; functio ...

  7. Oracle11.2.0.1 升级Oracle11.2.0.4 后 listener 的端口改变需要处理

    1. 因为Oracle采取了异地升级 发现 Oracle的端口号发生了变化: 2. 如果之前的连接还需要用的话 需要禁用 dbhome1 里面的监听 只打开dbhome2的监听 并且修改 监听的端口号 ...

  8. centos7改中文

    centos7的与centos6有少许不同: 1.安装中文包: root@iZj6cbstl2n6r280a27eppZ tmp]# yum groupinstall "fonts" ...

  9. JavaScript高级程序设计 第六章 面向对象程序设计

    面向对象程序设计 ECMA-262将对象定义为:“无序属性的集合,其属性可以包含基本值.对象或者函数.”严格来讲,这就相当于说对象是一组没有特定顺序的值.对象的每个属性和方法都有一个名字,而每个名字都 ...

  10. WPF 如何控制右键菜单ContextMenu的弹出

    在具体做一些项目的时候,有时候需要需要先左键点击某个节点,然后再右键点击节点的时候才弹出右键菜单,所以直接右键点击时需要禁用掉右键菜单,这里比如我们为Grid添加了ContextMenu,但是我们需要 ...