题目传送门


题目描述

煤矿工地可以看成是由隧道连接挖煤点组成的无向图。为安全起见,希望在工地发生事故时所有挖煤点的工人都能有一条出路逃到救援出口处。于是矿主决定在某些挖煤点设立救援出口,使得无论哪一个挖煤点坍塌之后,其他挖煤点的工人都有一条道路通向救援出口。

请写一个程序,用来计算至少需要设置几个救援出口,以及不同最少救援出口的设置方案总数。


输入格式

输入文件有若干组数据,每组数据的第一行是一个正整数N(N≤500),表示工地的隧道数,接下来的N行每行是用空格隔开的两个整数S和T,表示挖煤点S与挖煤点T由隧道直接连接。输入数据以0结尾。


输出格式

输入文件中有多少组数据,输出文件中就有多少行。每行对应一组输入数据的结果。

其中第i行以Case i:开始(注意大小写,Case与i之间有空格,i与:之间无空格,:之后有空格),其后是用空格隔开的两个正整数,第一个正整数表示对于第i组输入数据至少需要设置几个救援出口,第二个正整数表示对于第i组输入数据不同最少救援出口的设置方案总数。输入数据保证答案小于${2}^{64}$。

输出格式参照以下输入输出样例。


样例

样例输入:

9
1 3
4 1
3 5
1 2
2 6
1 5
6 3
1 6
3 2
6
1 2
1 3
2 4
2 5
3 6
3 7
0

样例输出:

Case 1: 2 4
Case 2: 4 1


数据范围与提示

样例解释:
Case 1的四组解分别是(2,4),(3,4),(4,5),(4,6)(2,4),(3,4),(4,5),(4,6)(2,4),(3,4),(4,5),(4,6);
Case 2的一组解为(4,5,6,7)(4,5,6,7)(4,5,6,7)。

N≤500,输入数据保证答案小于${2}^{64}$


题解

首先,肯定是要考虑塔尖算法的,判除割点后,在一个强联通分量内分一下三种情况:

  1.如果没有割点需要建两个出口,因为有可能其中一个会坍塌。

  2.如果有一个割点,则在非割点的其中一个割点建一个出口,割点坍塌可以从这个出口逃出,如果这个出口坍塌则从割点出去。

  3.如果有两个即以上割点,则不用建出口,直接从其他个嗲逃出即可。

统计完这三种情况之后,用乘法原理计算答案即可。


代码时刻

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. struct rec
  4. {
  5. int nxt;
  6. int to;
  7. }e[100001];
  8. int n;
  9. int head[100001],cnt;
  10. int dfn[100001],low[100001],sta[100001],top,tot,root;
  11. bool cut[100001];
  12. int ans;
  13. long long sum;
  14. vector<int> dcc[100001];
  15. int biu;
  16. void pre_work()
  17. {
  18. cnt=1;
  19. top=0;
  20. tot=0;
  21. ans=0;
  22. sum=1;
  23. n=0;
  24. memset(dfn,0,sizeof(dfn));
  25. memset(low,0,sizeof(low));
  26. memset(head,0,sizeof(head));
  27. memset(sta,0,sizeof(sta));
  28. memset(cut,0,sizeof(cut));
  29. }
  30. void add(int x,int y)
  31. {
  32. e[++cnt].nxt=head[x];
  33. e[cnt].to=y;
  34. head[x]=cnt;
  35. }
  36. void tarjan(int x)//塔尖判割点
  37. {
  38. dfn[x]=low[x]=++tot;
  39. sta[++top]=x;
  40. int flag=0;
  41. for(int i=head[x];i;i=e[i].nxt)
  42. {
  43. if(!dfn[e[i].to])
  44. {
  45. tarjan(e[i].to);
  46. low[x]=min(low[x],low[e[i].to]);
  47. if(dfn[x]<=low[e[i].to])
  48. {
  49. flag++;
  50. if(x!=root||flag>1)cut[x]=1;
  51. cnt++;
  52. dcc[cnt].clear();
  53. int y;
  54. do
  55. {
  56. y=sta[top--];
  57. dcc[cnt].push_back(y);
  58. }while(e[i].to!=y);
  59. dcc[cnt].push_back(x);
  60. }
  61. }
  62. else low[x]=min(low[x],dfn[e[i].to]);
  63. }
  64. }
  65. int main()
  66. {
  67. while(1)
  68. {
  69. int m;
  70. scanf("%d",&m);
  71. if(!m)break;
  72. pre_work();
  73. for(int i=1;i<=m;i++)
  74. {
  75. int x,y;
  76. scanf("%d%d",&x,&y);
  77. add(x,y);
  78. add(y,x);
  79. n=max(n,max(x,y));
  80. }
  81. cnt=0;
  82. for(int i=1;i<=n;i++)
  83. if(!dfn[i])root=i,tarjan(i);
  84. if(cnt==1)
  85. {
  86. printf("Case %d: 2 %lld\n",++biu,1LL*n*(n-1)/2);//特判
  87. continue;
  88. }
  89. for(int i=1;i<=cnt;i++)
  90. {
  91. int flag=0;
  92. for(int j=0;j<dcc[i].size();j++)
  93. if(cut[dcc[i][j]])flag++;
  94. if(flag==1)
  95. {
  96. ans++;
  97. sum*=dcc[i].size()-1;//乘法原理统计答案
  98. }
  99. }
  100. printf("Case %d: %d %lld\n",++biu,ans,sum);
  101. }
  102. return 0;
  103. }

rp++​​。

[BZOJ2730]:[HNOI2012]矿场搭建(塔尖)的更多相关文章

  1. bzoj2730 [HNOI2012]矿场搭建 (UVAlive5135 Mining Your Own Business)

    2730: [HNOI2012]矿场搭建 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1147  Solved: 528[Submit][Statu ...

  2. [BZOJ2730][HNOI2012]矿场搭建 点双 割点

    2730: [HNOI2012]矿场搭建 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 2852  Solved: 1344[Submit][Stat ...

  3. BZOJ2730——[HNOI2012]矿场搭建

    bzoj2730 & world final 2011 H 1.题目大意:就是有一个无向图,让你在里面选择点,使得,无论哪个点没了以后,其他的点都能到达你选择的任何一个点,输出最少 选择几个点 ...

  4. BZOJ2730 [HNOI2012]矿场搭建 - Tarjan割点

    Solution 输入中没有出现过的矿场点是不用考虑的, 所以不用考虑只有 一个点 的点双联通分量. 要使某个挖矿点倒塌, 相当于割去这个点, 所以我们求一遍割点和点双联通分量. 之后的点双联通分量构 ...

  5. BZOJ2730: [HNOI2012]矿场搭建

    传送门 图的连通性相关的必和割点割边之类的有关. 题目要求对于一个无向图,任意一点被删除后,所有点都和某些指定点是联通的. 这道题比较简单的做法就是求出来所有的块.对于一个块,如果块里有两个及两个以上 ...

  6. [BZOJ2730][HNOI2012]矿场搭建(求割点)

    题目:http://www.lydsy.com:808/JudgeOnline/problem.php?id=2730 分析: 如果坍塌的点不是割点,那没什么影响,主要考虑坍塌的点是割点的情况. 显然 ...

  7. 【双连通分量】Bzoj2730 HNOI2012 矿场搭建

    Description 煤矿工地可以看成是由隧道连接挖煤点组成的无向图.为安全起见,希望在工地发生事故时所有挖煤点的工人都能有一条出路逃到救援出口处.于是矿主决定在某些挖煤点设立救援出口,使得无论哪一 ...

  8. BZOJ2730:[HNOI2012]矿场搭建(双连通分量)

    Description 煤矿工地可以看成是由隧道连接挖煤点组成的无向图.为安全起见,希望在工地发生事故时所有挖煤点的工人都能有一条出路逃到救援出口处.于是矿主决定在某些挖煤点设立救援出口,使得无论哪一 ...

  9. BZOJ2730 [HNOI2012]矿场搭建[点双连通分量]

    看到删去一个点,需要剩下的都和关键点连通,有端联想到找点双,因为他怎么删点都是连通的. 对于一个孤立的点双,至少要设两个关键点. 如果两个点双以一个割点连接,假设断掉这个割点,两个块至少要各设一个关键 ...

随机推荐

  1. ubuntu14.04 x86编译upx 3.92 及so加固

    的参考文章: http://www.cnblogs.com/fishou/p/4202061.html 1.download upx和所依赖的组件 upx3.:https://www.pysol.or ...

  2. 适配方案(二)之PC端适配

    PC端 特点 PC端的屏幕具备以下特点: 屏幕大小一般是大于 13.3英寸 用户会经常拖拉浏览器的大小 原因 正是因为 PC端上的浏览器大小会经常被改变,而且改变的范围还很大,用户会全屏浏览器,用户也 ...

  3. O057、Delete Volume 操作

    参考https://www.cnblogs.com/CloudMan6/p/5648665.html   状态为Available 的volume 才能够被delete,如果volume当前已经被at ...

  4. Laravel 查询数据按照时间分组

    首先取消严格模式: // config/database.php // 'strict' => true, // 严谨模式注释掉 查询构造器代码: //查询构造器部分代码 })->with ...

  5. PHP获取某段文字作为标题

    <?php mb_internal_encoding('utf-8'); // 提取文字标题,多余文字用省略号替换 $arr=[ '用心用情用功,进行无愧于时代的文艺创造', '一图了解第二届一 ...

  6. ChinaCock扫描控件介绍-使用TCCBarcodeScanner引起app闪退

    好几个ChinaCock的朋友说遇到扫码时闪退,进一步总结,都是Android 8的机器上才会出现,今天我也遇到.正好有朋友说,按下面这个改配置文件就可以解决: <!-- 扫描的activity ...

  7. Docker_云计算技术简述

    Docker官方网站 > https://www.docker.com/Docker博客 > https://www.docker.com/blog/Docker内容库 > http ...

  8. Tomcat集成到MyEclipse

    1.Tomcat集成到MyEclipse 使用MyEclipse配置服务器后,就可以使用MyEclipse来启动和停止服务器了.当然,你需要先安装好服务器(Tomcat),才能配置.MyEclipse ...

  9. oracle下关于table的常用sql整理

    创建表,create TABLE table( 列名称1 数据类型1, 列名称2 数据类型2, 列名称3 数据类型3, ......); eg: create table TABLE_24751( i ...

  10. ScrollView 滚动视图

    ScrollView 种类: 1.HorizontalScrollView:水平滚动视图 2.ScrollView:垂直滚动视图(常用类) public class MainActivity exte ...