【刷题】BZOJ 2730 [HNOI2012]矿场搭建
Description
Input
输入文件有若干组数据,每组数据的第一行是一个正整数 N(N≤500),表示工地的隧道数,接下来的 N 行每行是用空格隔开的两个整数 S 和 T,表示挖煤点 S 与挖煤点 T 由隧道直接连接。输入数据以 0 结尾。
Output
输入文件中有多少组数据,输出文件 output.txt 中就有多少行。每行对应一组输入数据的 结果。其中第 i 行以 Case i: 开始(注意大小写,Case 与 i 之间有空格,i 与:之间无空格,: 之后有空格),其后是用空格隔开的两个正整数,第一个正整数表示对于第 i 组输入数据至少需 要设置几个救援出口,第二个正整数表示对于第 i 组输入数据不同最少救援出口的设置方案总 数。输入数据保证答案小于 2^64。输出格式参照以下输入输出样例。
Sample Input
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
Sample Output
Case 2: 4 1
HINT
Solution
先对题目中给出的图跑一遍Tarjan,把点双和割点都求出来
然后我们发现对于每个点双,存在三种情况
1)点双中不存在割点,那么我们就要在其中最少建2个,这样就算其中有一个塌了,由于这是个点双,其它所有点还是与救生点是连通的
2)点双中只存在一个割点,那么就在除割点之外任意一个点建1个,这样如果割点塌了,其它点可以赶到救援出口;如果是救援出口塌了,那么其它点可以通过割点走到其它联通块去
3)点双中存在一个以上的割点,那么无论是那个点塌了,其它点都可以通过(剩下的)割点走到其它联通块去
对于方案数的话,用组合数可以直接算
#include<bits/stdc++.h>
using namespace std;
#define ll long long
const int MAXN=+;
int n,m,e,to[MAXN<<],nex[MAXN<<],beg[MAXN],out[MAXN],DFN[MAXN],LOW[MAXN],Visit_Num,Be[MAXN],cnt,cut[MAXN],cas,val[MAXN],C[MAXN][MAXN];
ll ans1,ans2;
stack<int> s;
vector<int> point[MAXN];
inline void read(int &x)
{
int data=,w=;
char ch=;
while(ch!='-'&&(ch<''||ch>''))ch=getchar();
if(ch=='-')w=-,ch=getchar();
while(ch>=''&&ch<='')data=(data<<)+(data<<)+(ch^''),ch=getchar();
x=data*w;
}
inline void preinit()
{
C[][]=;
for(register int i=;i<MAXN;++i)
{
C[i][]=;
for(register int j=;j<=i;++j)C[i][j]=C[i-][j]+C[i-][j-];
}
}
inline void init()
{
n=;ans1=;ans2=;cnt=;e=;
memset(Be,,sizeof(Be));
memset(beg,,sizeof(beg));
memset(cut,,sizeof(cut));
memset(DFN,,sizeof(DFN));
memset(LOW,,sizeof(LOW));
memset(val,,sizeof(val));
while(!s.empty())s.pop();
}
inline void insert(int x,int y)
{
to[++e]=y;
out[e]=x;
nex[e]=beg[x];
beg[x]=e;
}
inline void Tarjan(int x,int f)
{
int ch=;
DFN[x]=LOW[x]=++Visit_Num;
for(register int i=beg[x];i;i=nex[i])
if(to[i]==f)continue;
else if(!DFN[to[i]])
{
s.push(i);
ch++;
Tarjan(to[i],x);
LOW[x]=min(LOW[x],LOW[to[i]]);
if(LOW[to[i]]>=DFN[x])
{
cut[x]=;
int temp;
++cnt;
point[cnt].clear();
do{
temp=s.top();
s.pop();
if(Be[out[temp]]!=cnt)
{
Be[out[temp]]=cnt;
point[cnt].push_back(out[temp]);
}
if(Be[to[temp]]!=cnt)
{
Be[to[temp]]=cnt;
point[cnt].push_back(to[temp]);
}
}while(out[temp]!=x||to[temp]!=to[i]);
}
}
else if(DFN[to[i]]<DFN[x])
{
s.push(i);
LOW[x]=min(LOW[x],DFN[to[i]]);
}
if(!f&&ch<)cut[x]=;
}
inline void statistic()
{
for(register int i=;i<=cnt;++i)
{
for(register int j=;j<point[i].size();++j)
if(cut[point[i][j]])val[i]++;
if(val[i]==)ans1+=2ll,ans2*=(ll)C[point[i].size()][];
else if(val[i]==)ans1++,ans2*=(ll)C[point[i].size()-][];
}
}
int main()
{
preinit();
while(scanf("%d",&m)!=EOF&&m)
{
printf("Case %d:",++cas);
init();
for(register int i=;i<=m;++i)
{
int u,v;
read(u);read(v);
insert(u,v);
insert(v,u);
n=max(n,max(u,v));
}
for(register int i=;i<=n;++i)
if(!DFN[i])Tarjan(i,);
statistic();
printf(" %lld %lld\n",ans1,ans2);
}
return ;
}
2730 矿场搭建
【刷题】BZOJ 2730 [HNOI2012]矿场搭建的更多相关文章
- BZOJ 2730: [HNOI2012]矿场搭建( tarjan )
先tarjan求出割点.. 割点把图分成了几个双连通分量..只需dfs找出即可. 然后一个bcc有>2个割点, 那么这个bcc就不用建了, 因为一定可以走到其他救援出口. 只有一个割点的bcc就 ...
- bzoj 2730: [HNOI2012]矿场搭建
#include<cstdio> #include<cstring> #include<iostream> #define M 508 using namespac ...
- bzoj 2730: [HNOI2012]矿场搭建——tarjan求点双
Description 煤矿工地可以看成是由隧道连接挖煤点组成的无向图.为安全起见,希望在工地发生事故时所有挖煤点的工人都能有一条出路逃到救援出口处.于是矿主决定在某些挖煤点设立救援出口,使得无论哪一 ...
- bzoj 2730: [HNOI2012]矿场搭建【tarjan】
先tarjan找割点和点双连通分量,然后对一个点双,如果没有割点,那么需要建立两个出口(割掉一个另一个备用):如果只有一个割点,出口可以设立在任意一个非割点的地方:如果有两个及以上个割点,就不用建出口 ...
- 【BZOJ】2730: [HNOI2012]矿场搭建【Tarjan找割点】【分联通块割点个数】
2730: [HNOI2012]矿场搭建 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 3230 Solved: 1540[Submit][Stat ...
- Tarjan水题系列(2):HNOI2012 矿场搭建
题目: 煤矿工地可以看成是由隧道连接挖煤点组成的无向图.为安全起见,希望在工地发生事故时所有挖煤点的工人都能有一条出路逃到救援出口处.于是矿主决定在某些挖煤点设立救援出口,使得无论哪一个挖煤点坍塌之后 ...
- bzoj2730 [HNOI2012]矿场搭建 (UVAlive5135 Mining Your Own Business)
2730: [HNOI2012]矿场搭建 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1147 Solved: 528[Submit][Statu ...
- [BZOJ2730][HNOI2012]矿场搭建 点双 割点
2730: [HNOI2012]矿场搭建 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 2852 Solved: 1344[Submit][Stat ...
- BZOJ 2730:[HNOI2012]矿场搭建(割点+连通块)
[HNOI2012]矿场搭建 Description 煤矿工地可以看成是由隧道连接挖煤点组成的无向图.为安全起见,希望在工地发生事故时所有挖煤点的工人都能有一条出路逃到救援出口处.于是矿主决定在某些挖 ...
随机推荐
- Jmeter实战
Jmeter实战 入门篇 1.下载与使用 下载地址:http://jmeter.apache.org/download_jmeter.cgi 开源,基于java编写,所以得有jdk(jre)环境,下载 ...
- https、ssl、tls协议学习
一.知识准备 1.ssl协议:通过认证.数字签名确保完整性:使用加密确保私密性:确保客户端和服务器之间的通讯安全 2.tls协议:在SSL的基础上新增了诸多的功能,它们之间协议工作方式一样 3.htt ...
- 用python实现数字图片识别神经网络--启动网络的自我训练流程,展示网络数字图片识别效果
上一节,我们完成了网络训练代码的实现,还有一些问题需要做进一步的确认.网络的最终目标是,输入一张手写数字图片后,网络输出该图片对应的数字.由于网络需要从0到9一共十个数字中挑选出一个,于是我们的网络最 ...
- Bing词典vs有道词典比对测试报告——功能篇之核心功能
必应词典vs有道词典 核心功能对比 从应用的UI布局来看,这两款软件的功能如下: 相同 不同 必应词典 词典.例句.翻译 百科 有道词典 词典.例句.翻译 应用 就词典类软件来说,词典是最核心的功能. ...
- 20135234mqy-——信息安全系统设计基础第七周学习总结
第六章 存储器层次结构 存储器系统是一个具有不同容量,成本和访问时间的存储设备的层次结构. CPU寄存器保存着最常用的数据. 靠近CPU的小的,快速的高速缓存存储器作为一部分存储在相对较慢的主存储器( ...
- Hive问题
今天一直遇到一个问题: 在查询最热10个关键词时候总是报错,下图为报错最下面 一直关注着failed的内容,头疼了一天......... 结果实验室老哥给指出问题,是yarnException报错, ...
- matconvnet编译
1.安装matconvnet 网上教程很多 2.编译 cd matconvnet/ addpath matlab/ vl_compilenn('enableGpu',true,'cudaRoot',' ...
- Reaction to 构造之法 of Software Engineering From The First Chapter toThe Fifth Chapter
几个星期前,我阅读过一篇文章,一位老师教导自己的学生要积极地去阅读文学文献,其中,我很欣赏他的一句话:“Just think of liturature as if you're reading a ...
- 第一次spring冲刺第9天
明天是这个阶段的最后一天了,今天讨论关于容错的方面,例如输入空白或其他字符等方面会出现的问题 ,部分代码如下: public void checkout(int trueResult) { Strin ...
- #1490 : Tree Restoration
微软 2017春招真题 题目 There is a tree of N nodes which are numbered from 1 to N. Unfortunately, its edges a ...