题目背景

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

题目描述

共有\(n\)所学校\((n \leq 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\)倍。

\(边数 \leq 5000000 ≤ 5000000\)

思路:这道题是洛谷\(P2746\)的数据加强版,但是……还是没法卡掉\(tarjan\)做法啊,毕竟正解就是\(tarjan\),直接把洛谷\(P2746\)的代码粘过来然后把数组改大些就可以了……

代码:

  1. #include<cstdio>
  2. #include<iostream>
  3. #include<stack>
  4. #define maxn 10007
  5. using namespace std;
  6. int n,num,js,cnt,rd[maxn],cd[maxn],head[maxn],dfn[maxn],low[maxn],bel[maxn],size[maxn];
  7. int x1,x2;
  8. bool vis[maxn];
  9. struct node {
  10. int v,nxt;
  11. }e[5000007];
  12. inline void ct(int u, int v) {
  13. e[++num].v=v;
  14. e[num].nxt=head[u];
  15. head[u]=num;
  16. }
  17. inline int maxx(int a, int b) {return a>=b?a:b;}
  18. stack<int>q;
  19. void tarjan(int u) {
  20. dfn[u]=low[u]=++cnt;
  21. q.push(u),vis[u]=1;
  22. for(int i=head[u];i;i=e[i].nxt) {
  23. int v=e[i].v;
  24. if(!dfn[v]) tarjan(v),low[u]=min(low[u],low[v]);
  25. else if(vis[v]) low[u]=min(low[u],dfn[v]);
  26. }
  27. if(dfn[u]==low[u]) {
  28. int x=-1;js++;
  29. while(x!=u) {
  30. x=q.top(),q.pop();
  31. bel[x]=js,size[js]++;
  32. vis[x]=0;
  33. }
  34. }
  35. }
  36. int main() {
  37. scanf("%d",&n);
  38. for(int i=1,x;i<=n;++i) {
  39. while(scanf("%d",&x)==1) {
  40. if(!x) break;
  41. ct(i,x);
  42. }
  43. }
  44. for(int i=1;i<=n;++i) if(!dfn[i]) tarjan(i);
  45. if(js==1) {printf("1\n0\n");return 0;};
  46. for(int k=1;k<=n;++k) {
  47. for(int i=head[k];i;i=e[i].nxt) {
  48. int v=e[i].v;
  49. if(bel[k]!=bel[v]) ++cd[bel[k]],++rd[bel[v]];
  50. }
  51. }
  52. for(int i=1;i<=js;++i) {
  53. if(!cd[i]) ++x1;
  54. if(!rd[i]) ++x2;
  55. }
  56. printf("%d\n%d\n",x2,max(x1,x2));
  57. return 0;
  58. }

洛谷P2812校园网络【Network of Schools加强版】的更多相关文章

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

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

  2. 洛谷—— P2812 校园网络

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

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

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

  4. 洛谷P2812校园网络

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

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

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

  6. 洛谷 P4665 [BalticOI 2015]Network

    洛谷 P4665 [BalticOI 2015]Network 你有一棵 $ n $ 个节点的树,你可以在树上加一些边,使这棵树变成一张无重边.自环的图,且删掉任意一条边它仍然联通.求最少要加多少条边 ...

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

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

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

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

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

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

随机推荐

  1. BZOJ4317: Atm的树+2051+2117

    BZOJ4317: Atm的树+2051+2117 https://lydsy.com/JudgeOnline/problem.php?id=4317 分析: 二分答案之后就变成震波那道题了. 冷静一 ...

  2. bzoj 4504: K个串 可持久化线段树+堆

    题目: Description 兔子们在玩k个串的游戏.首先,它们拿出了一个长度为n的数字序列,选出其中的一 个连续子串,然后统计其子串中所有数字之和(注意这里重复出现的数字只被统计一次). 兔子们想 ...

  3. RenderMonkey基本使用方法

    http://www.cnblogs.com/mixiyou/archive/2009/10/05/1578208.html 楔子: 差不多从年中开始由于工作需要,开始研究Direct3D,这是继大二 ...

  4. codeblocks如何支持_tmain?可移植代码的编码推荐

    codeblocks默认源代码文件编码根据OS而定,编译时编码UTF-8. 在你不更改任何codeblocks配置时:                    在WINDOWS中:源代码——WINDOW ...

  5. C#调试信息打印到输出窗口

    System.Diagnostics.Debug.WriteLine("aaaa");

  6. 【转】 Pro Android学习笔记(六四):安全和权限(1):签发apk

    目录(?)[-] Android安全模型 数字证书签发 Debug的keystore 生产unsigned的apk 为apk进行证书签发 align安装包 使用Export Wizard生成签发的ap ...

  7. System.getProperty()获取系统的相关属性

    我们在编程的过程中有时候需要获取系统的相关属性,今天就让我们一起来学习学习如何获取系统的相关属性 至于System.getProperty(param)中的各个参数的概念请看下表. java.vers ...

  8. 三 Flask web开发快速入门

    1:会话: from flask import Flask, url_for, request, render_template, session from werkzeug.utils import ...

  9. cisco 2901 配置拨号上网

    1.输入en,然后输入密码确认后按conf t2.Router(config)# vpdn enable        interface dialer 1   // 进入拨号器13.Router(c ...

  10. SpringSecurity01 SpringSecurity环境搭建

    版本说明: JDK -> java version "1.8.0_101" MAVEN -> Apache Maven 3.5.0 IDEA -> 2017.2. ...