P1230 备用交换机

From easthong☆备用交换机
描述 Description
     n个城市之间有通讯网络,每个城市都有通讯交换机,直接或间接与其它城市连接。因电子设备容易损坏,需给通讯点配备备用交换机。但备用 交换机数量有限,不能全部配备,只能给部分重要城市配置。于是规定:如果某个城市由于交换机损坏,不仅本城市通讯中断,还造成其它城市通讯中断,则配备备 用交换机。请你根据城市线路情况,计算需配备备用交换机的城市个数,及需配备备用交换机城市的编号。
输入格式 Input Format
     第一行,一个整数n,表示共有n个城市(2<=n<=20000)
下面有若干行(<=60000):每行2个数a、b,a、b是城市编号,表示a与b之间有直接通讯线路。
输出格式 Output Format
     第一行,1个整数m,表示需m个备用交换机,下面有m行,每行有一个整数,表示需配备交换机的城市编号,输出顺序按编号由小到大。如果没有城市需配备备用交换机则输出0。
样例输入 Sample Input    

7
1 2
2 3
2 4
3 4
4 5
4 6
4 7
5 6
6 7

样例输出 Sample Output    

2
2
4

时间限制 Time Limitation
     1s

题目

一个割点的板子题

代码如下

 1 #include <bits/stdc++.h>
 2 using namespace std;
 3 inline int read(){
 4     int x=0;int f=1;char ch=getchar();
 5     while(!isdigit(ch)) {if(ch==‘-‘) f=-1;ch=getchar();}
 6     while(isdigit(ch)) {x=x*10+ch-‘0‘;ch=getchar();}
 7     return x*f;
 8 }
 9 const int MAXN=1e6+10;
10 namespace zhangenming{
11     struct node{
12         int y,next;
13     }e[MAXN<<1];
14     int linkk[MAXN<<1],len=0,n,m,low[MAXN],dfn[MAXN]={},dfs_clock=0,ans[MAXN],tmp=0,vis[MAXN]={};
15     inline void insert(int xx,int yy){
16         e[++len].y=yy;e[len].next=linkk[xx];linkk[xx]=len;
17     }
18     void init(){
19         n=read();
20         int xx,yy;
21         while(scanf("%d%d",&xx,&yy)!=EOF){
22             insert(xx,yy);
23             insert(yy,xx);
24         }
25     }
26     void tarjin(int st,int father){
27         dfn[st]=low[st]=++dfs_clock;
28         vis[st]=1;
29         int son=0;
30         for(int i=linkk[st];i;i=e[i].next){
31             if(e[i].y!=father&&!dfn[e[i].y]){
32                 tarjin(e[i].y,st);
33                 if(low[e[i].y]<low[st]) low[st]=low[e[i].y];
34                 if(low[e[i].y]>=dfn[st]) son++;
35             }
36             else if(dfn[e[i].y]<low[st]) low[st]=dfn[e[i].y];
37         }
38         if(son>=2||son&&father) ans[++tmp]=st;
39     }
40     void solve(){
41         for(int i=1;i<=n;i++){
42             if(!vis[i]) tarjin(i,0);
43         }
44         sort(ans+1,ans+tmp+1);
45         cout<<tmp<<endl;
46         for(int i=1;i<=tmp;i++){
47             printf("%d ",ans[i]);
48         }
49         cout<<endl;
50     }
51 }
52 int main(){
53     //freopen("aa.in","r",stdin);
54     //freopen("aa.out","w",stdout);
55     using namespace zhangenming;
56     init();
57     solve();
58     return 0;
59 }

注意图不一定联通

时间: 2024-08-03 09:16:04

P1230 备用交换机的相关文章

图的割点 | | jzoj【P1230】 | | gdoi | |备用交换机

写在前面:我真的不知道图的割点是什么.... 看见ftp图论专题里面有个dfnlow的一个文档,于是怀着好奇的心情打开了这个罪恶的word文档,,然后就开始漫长的P1230的征讨战.... 图的割点是这样的: path1=暴力 枚举每一个点,如果去掉这个点就可以使图断开,那么这个点就是割点(时间复杂度O(N(N+M))) path2=tarjan 从任意一个点开始遍历,记录遍历的顺序,然后对正在遍历的点进行一次深度优先遍历,但是此次遍历不允许经过这个点,看看还能不能回到前一个点 这时候我们就可以

COGS——T 8. 备用交换机

http://www.cogs.pro/cogs/problem/problem.php?pid=8 ★★   输入文件:gd.in   输出文件:gd.out   简单对比时间限制:1 s   内存限制:128 MB [问题描述] n个城市之间有通讯网络,每个城市都有通讯交换机,直接或间接与其它城市连接.因电子设备容易损坏,需给通讯点配备备用交换机.但备用交换机数量有限,不能全部配备,只能给部分重要城市配置.于是规定:如果某个城市由于交换机损坏,不仅本城市通讯中断,还造成其它城市通讯中断,则配

COGS 8. 备用交换机

8. 备用交换机 [问题描述] n个城市之间有通讯网络,每个城市都有通讯交换机,直接或间接与其它城市连接.因电子设备容易损坏,需给通讯点配备备用交换机.但备用交换机数量有限,不能全部配备,只能给部分重要城市配置.于是规定:如果某个城市由于交换机损坏,不仅本城市通讯中断,还造成其它城市通讯中断,则配备备用交换机.请你根据城市线路情况,计算需配备备用交换机的城市个数,及需配备备用交换机城市的编号. [输入格式] 输入文件有若干行第一行,一个整数n,表示共有n个城市(2<=n<=100)下面有若干行

备用交换机(cogs 8)

[问题描述] n个城市之间有通讯网络,每个城市都有通讯交换机,直接或间接与其它城市连接.因电子设备容易损坏,需给通讯点配备备用交换机.但备用交换机数量有限,不能全部配备,只能给部分重要城市配置.于是规定:如果某个城市由于交换机损坏,不仅本城市通讯中断,还造成其它城市通讯中断,则配备备用交换机.请你根据城市线路情况,计算需配备备用交换机的城市个数,及需配备备用交换机城市的编号. [输入格式] 输入文件有若干行第一行,一个整数n,表示共有n个城市(2<=n<=100)下面有若干行,每行2个数a.b

COGS8 备用交换机

备用交换机 ★★   输入文件:gd.in   输出文件:gd.out   简单对比时间限制:1 s   内存限制:128 MB [问题描述] n个城市之间有通讯网络,每个城市都有通讯交换机,直接或间接与其它城市连接.因电子设备容易损坏,需给通讯点配备备用交换机.但备用交换机数量有限,不能全部配备,只能给部分重要城市配置.于是规定:如果某个城市由于交换机损坏,不仅本城市通讯中断,还造成其它城市通讯中断,则配备备用交换机.请你根据城市线路情况,计算需配备备用交换机的城市个数,及需配备备用交换机城市

备用交换机

[题目描述] n个城市之间有通讯网络,每个城市都有通讯交换机,直接或间接与其它城市连接. 因电子设备容易损坏,需给通讯点配备备用交换机.但备用交换机数量有限,不能全部配备,只能给部分重要城市配置.于是规定:如果某个城市由于交换机损坏,不仅本城市通讯中断,还造成其它城市通讯中断,则配备备用交换机. 请你根据城市线路情况,计算需配备备用交换机的城市个数,及需配备备用交换机城市的编号. [输入描述] 第一行,一个整数n,表示共有n个城市(2 <= n <= 100): 下面有若干行,每行2个数a.b

EX4200交换机的VC配置

VC故名思义就是:virtual-chassis 虚拟机箱的意思.我们要明白为什么要这么用?用这个方法有什么好处.我们知道,一台交换机后面有两个VCP端口,每个端口提供32Gbps背板带宽,如果我们将这两个端口与另一台交换机的VCP端口连接起来,是不是就增加带宽了,为64Gbps了.这是一点很明显的好处,处理数据的能力及转发状态更加行之有效了,同时这样的好处就是两台可视为一台处理了,而且互作冷备.主路由引擎上的核心信息和转发状态都会复制一份给备机,不会出现网络中断情况,几乎在瞬间完成.下面我来详

COGS 08-备用交换机 题解——S.B.S.

8. 备用交换机 ★★   输入文件:gd.in   输出文件:gd.out   简单对比时间限制:1 s   内存限制:128 MB [问题描述] n个城市之间有通讯网络,每个城市都有通讯交换机,直接或间接与其它城市连接.因电子设备容易损坏,需给通讯点配备备用交换机.但备用交换机数量有限,不能全部配备,只能给部分重要城市配置.于是规定:如果某个城市由于交换机损坏,不仅本城市通讯中断,还造成其它城市通讯中断,则配备备用交换机.请你根据城市线路情况,计算需配备备用交换机的城市个数,及需配备备用交换

tarjan算法求割点cojs 8

tarjan求割点:cojs 8. 备用交换机 ★★   输入文件:gd.in   输出文件:gd.out   简单对比时间限制:1 s   内存限制:128 MB [问题描述] n个城市之间有通讯网络,每个城市都有通讯交换机,直接或间接与其它城市连接.因电子设备容易损坏,需给通讯点配备备用交换机.但备用交换机数量有限,不能全部配备,只能给部分重要城市配置.于是规定:如果某个城市由于交换机损坏,不仅本城市通讯中断,还造成其它城市通讯中断,则配备备用交换机.请你根据城市线路情况,计算需配备备用交换