P2812 校园网络

题目背景

浙江省的几所OI强校的神犇发明了一种人工智能,可以AC任何题目,所以他们决定建立一个网络来共享这个软件。但是由于他们脑力劳动过多导致全身无力身体被♂掏♂空,他们来找你帮助他们。

题目描述

共有n所学校(n<=10000)已知他们实现设计好的网络共m条线路,为了保证高速,网络是单向的。现在请你告诉他们至少选几所学校作为共享软件的母机母鸡,能使每所学校都可以用上。再告诉他们至少要添加几条线路能使任意一所学校作为母机母鸡都可以使别的学校使用上软件。

输入输出格式

输入格式:

第一行一个整数n。

接下来n行每行有若干个整数,用空格空格隔开。

第i-1行的非零整数x,表示从i到x有一条线路。以0作为结束标志。

输出格式:

第一行一个整数表示问题1的答案。

第二行回答问题2.

输入输出样例

输入样例#1:

  1. 5
  2. 2 0
  3. 4 0
  4. 5 0
  5. 1 0
  6. 0
输出样例#1:

  1. 2
  2. 2

说明

POJ原题。数据扩大了100倍。

tarjan求强连通分量水题

求出强连通分量以后,我们知道入度为零的点就是无信息来源的点。

强连通分量满足该强连通分量中无入度为零的点以及出度为零的点,那么我们要添加的边的条数就是max(入度为零的点的个数,出度为零的点的个数)

代码:

  1. #include<cstdio>
  2. #include<cstring>
  3. #include<cstdlib>
  4. #include<iostream>
  5. #include<algorithm>
  6. #define N 100000
  7. using namespace std;
  8. bool vis[N];
  9. int n,x,top,tim,tot,sum,ans,ans1,ans2;
  10. int in[N],out[N],dfn[N],low[N],head[N],stack[N],belong[N];
  11. int read()
  12. {
  13. ,f=; char ch=getchar();
  14. ; ch=getchar();}
  15. +ch-'; ch=getchar();}
  16. return x*f;
  17. }
  18. struct Edge
  19. {
  20. int from,to,next;
  21. }edge[N];
  22. int add(int x,int y)
  23. {
  24. tot++;
  25. edge[tot].to=y;
  26. edge[tot].next=head[x];
  27. head[x]=tot;
  28. }
  29. int tarjan(int now)
  30. {
  31. dfn[now]=low[now]=++tim;
  32. stack[++top]=now;vis[now]=true;
  33. for(int i=head[now];i;i=edge[i].next)
  34. {
  35. int t=edge[i].to;
  36. if(vis[t]) low[now]=min(low[now],dfn[t]);
  37. else if(!dfn[t]) tarjan(t),low[now]=min(low[now],low[t]);
  38. }
  39. if(low[now]==dfn[now])
  40. {
  41. sum++,belong[now]=sum;
  42. for(;stack[top]!=now;top--)
  43. {
  44. int t=stack[top];
  45. belong[t]=sum,vis[t]=false;
  46. }
  47. vis[now]=false; top--;
  48. }
  49. }
  50. int shink_point()
  51. {
  52. ;i<=n;i++)
  53. for(int j=head[i];j;j=edge[j].next)
  54. {
  55. int t=edge[j].to;
  56. if(belong[i]!=belong[t])
  57. in[belong[t]]++,out[belong[i]]++;
  58. }
  59. }
  60. int main()
  61. {
  62. n=read();
  63. ;i<=n;i++)
  64. {
  65. )
  66. {
  67. x=read();
  68. ) break;
  69. add(i,x);
  70. }
  71. }
  72. ;i<=n;i++)
  73. if(!dfn[i]) tarjan(i);
  74. shink_point();
  75. ;i<=sum;i++)
  76. {
  77. ) ans1++;
  78. ) ans2++;
  79. }
  80. ans=max(ans1,ans2);
  81. printf("%d\n%d\n",ans1,ans);
  82. ;
  83. }

洛谷—— P2812 校园网络的更多相关文章

  1. 洛谷 P2812 校园网络【[USACO]Network of Schools加强版】 解题报告

    P2812 校园网络[[USACO]Network of Schools加强版] 题目背景 浙江省的几所OI强校的神犇发明了一种人工智能,可以AC任何题目,所以他们决定建立一个网络来共享这个软件.但是 ...

  2. 洛谷P2812 校园网络[数据加强版] [Tarjan]

    题目传送门 校园网络 题目背景 浙江省的几所OI强校的神犇发明了一种人工智能,可以AC任何题目,所以他们决定建立一个网络来共享这个软件.但是由于他们脑力劳动过多导致全身无力身体被♂掏♂空,他们来找你帮 ...

  3. 洛谷P2812校园网络【Network of Schools加强版】

    题目背景 浙江省的几所\(OI\)强校的神犇发明了一种人工智能,可以\(AC\)任何题目,所以他们决定建立一个网络来共享这个软件.但是由于他们脑力劳动过多导致全身无力身体被\(♂\)掏\(♂\)空,他 ...

  4. 洛谷P2812校园网络

    传送门啦 其实这个题只要读懂分析好题意就不是很难. 就是将一个有向图进行缩点操作,把一个强连通分量看成一个点,求入度为 0 的点和出度为 0 的点各有多少. 在这里先向大家推荐两个题目,建议大家先去看 ...

  5. 洛谷 P1546 最短网络 Agri-Net

    题目链接 https://www.luogu.org/problemnew/show/P1546 题目背景 农民约翰被选为他们镇的镇长!他其中一个竞选承诺就是在镇上建立起互联网,并连接到所有的农场.当 ...

  6. 洛谷P1546 最短网络 Agri-Net(最小生成树,Kruskal)

    洛谷P1546 最短网络 Agri-Net 最小生成树模板题. 直接使用 Kruskal 求解. 复杂度为 \(O(E\log E)\) . #include<stdio.h> #incl ...

  7. 【题解】洛谷P1262 间谍网络 (强连通分量缩点)

    洛谷P1262:https://www.luogu.org/problemnew/show/P1262 思路 一看题目就知道是强连通分量缩点 当图中有强连通分量时 将其缩点 我们可以用dfn数组判断是 ...

  8. 洛谷 1262 间谍网络 Tarjan 图论

    洛谷 1262 图论 tarjan 并不感觉把这道题目放在图的遍历中很合适,虽然思路比较简单但是代码还是有点多的,, 将可收买的间谍的cost值设为它的价格,不可购买的设为inf,按照控制关系连图,T ...

  9. 洛谷$P2604\ [ZJOI2010]$网络扩容 网络流

    正解:网络流 解题报告: 传送门$QwQ$ 昂第一问跑个最大流就成不说$QwQ$ 然后第二问,首先原来剩下的边就成了费用为0的边?然后原来的所有边连接的两点都给加上流量为$inf$费用为$w$的边,保 ...

随机推荐

  1. phpstorm设置代码块快捷方式

    File -> Settings -> Live Templates

  2. Java递归调用改成非递归

          在java语言中,使用递归调用时,如果过多的调用容易造成java.lang.StackOverflowError即栈溢出和程序执行过慢.这是一个潜在Bug和影响程序执行效率问题,需要谨慎使 ...

  3. C# 移动开发 MasterDetailPage 关闭时报错问题

    至上次发表的 MasterDetailPage界面做主App,折腾10天,终于知道问题所在.. 泪奔的是解决这个问题只要一句代码 在MainActivity.cs里 [Activity(Label = ...

  4. 嵌入式ARM开发板学习方法步骤

    嵌入式开发就是指在嵌入式操作系统下进行开发,一般常用的系统有linux,android. 平台:Cortex-A9开发板 嵌入式技术学习如何入手,从何学起呢, 以下内容简单介绍嵌入式开发的学习步骤及如 ...

  5. (转)SpringMVC学习(八)——SpringMVC中的异常处理器

    http://blog.csdn.net/yerenyuan_pku/article/details/72511891 SpringMVC在处理请求过程中出现异常信息交由异常处理器进行处理,自定义异常 ...

  6. leetcode_41. First Missing Positive_cyclic swapping

    https://leetcode.com/problems/first-missing-positive/ 给定一个长度为len的无序数组nums,找到其第一个丢失的正整数. 解法: 使用cyclic ...

  7. HashSet LinkedHashSet TreeSet 分析

    1.HashSet分析 hashset 底层是hash表,就是hashMap,是无序的,唯一的.也就是说,它的底层其实就是一个HashMap  key 值的组成值.所以具有唯一性. public Ha ...

  8. Python 中列表、元祖、字典

    1.元祖: 对象有序排列,通过索引读取读取, 对象不可变,可以是数字.字符串.列表.字典.其他元祖 2.列表: 对象有序排列,通过索引读取读取, 对象是可变的,可以是数字.字符串.元祖.其他列表.字典 ...

  9. shell 数值比较和字符串比较

    1. 数值比较 -eq        是否相等(equal) -gt         是否大于(greater than) -ge       是否大于等于(greater and equal tha ...

  10. Python3基础教程(十九)—— 项目结构

    本节阐述了一个完整的 Python 项目结构,你可以使用什么样的目录布局以及怎样发布软件到网络上. 创建Python项目 我们的实验项目名为 factorial,放到 /home/shiyanlou/ ...