HLG 1494网络 (求的割点数目)可做模板
| 网络 | ||||||
 
  | 
||||||
| Description | ||||||
| 一个电话公司建立了一个新的电话网,他们用1——N的整数标记了一些地方,每个地方有唯一的编号,网络中的每条电缆双向连接了两个地方,从每个地方可以通过电缆连接到任意其他的地方,因为它们之间不一定要有直接相连的电缆,可以通过其他的电缆间接连接,有的时候某个地方的电力可能会中断,从而导致这个地方无法被连接,电话公司意识到了某些地方的电力中断可能会导致其他地方也无法互相连接,把这些地方叫做关键点,所以他们决定写一个程序去找到这些地方。 | ||||||
| Input | ||||||
| 每组输入是一个电话网络,每组的第一行是一个整数N<100,表示电话网络连接了N个地点,接下来是不超过N行整数,每行表示第一个整数与后面的整数表示的地点之间有电缆直接相连,每组数据以0结束,输入也以0结束。 | ||||||
| Output | ||||||
| 输出关键点的数量 | ||||||
| Sample Input | ||||||
5 5 1 2 3 4 0 6 2 1 3 5 4 6 2 0 0  | 
||||||
| Sample Output | ||||||
| 1
 2  | 
#include<iostream>
#include<stdio.h>
#include<string.h>
#define N 110
using namespace std;
int dfn[N], low[N];
bool mark[N], ans[N];
bool edge[N][N];
int cnt, son, n;
int min(int a, int b)
{
return a < b ? a : b;
}
void unit()
{
memset(edge, , sizeof(edge));
memset(mark, , sizeof(mark));
memset(ans, , sizeof(ans));
cnt=; son=;
mark[]=low[]=dfn[]=;
} void dfs(int u)
{
for(int v=;v<=n;v++)
{
if(edge[u][v])
{
if(!mark[v])
{
mark[v]=;
dfn[v]=low[v]=++cnt;
dfs(v);
low[u]=min(low[u],low[v]);
if(low[v]>=dfn[u])
{
if(u!=) ans[u]=;
else son++;
}
}
else low[u]=min(low[u],dfn[v]);
}
}
return ;
} int main()
{
int i;
char str[];
while(cin >> n)
{
if(n==) break;
getchar();
unit();
while(true)
{
gets(str);
if(strcmp(str, "")==) break;
int len=strlen(str);
int num=;
for(i=; str[i]>=''&&str[i]<=''; i++)
num=num*+str[i]-'';
for(;i<len; i++)
{
int m=;
for(;str[i]>=''&&str[i]<=''&&i<len; i++)
{
m=m*+str[i]-'';
}
if(m!=) edge[num][m]=edge[m][num]=;
}
}
dfs();
int js=;
for(int j=; j<=n; j++)
js+=ans[j];
if(son>=) cout << js+ << endl;
else cout << js << endl;
}
return ;
}
HLG 1494网络 (求的割点数目)可做模板的更多相关文章
- 求割点模板(可求出割点数目及每个割点分割几个区域)POJ1966(Cable TV Network)
		
题目链接:传送门 题目大意:给你一副无向图,求解图的顶点连通度 题目思路:模板(图论算法理论,实现及应用 P396) Menger定理:无向图G的顶点连通度k(G)和顶点间最大独立轨数目之间存在如下关 ...
 - HDU 1269 -- 迷宫城堡【有向图求SCC的数目 && 模板】
		
迷宫城堡 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submi ...
 - ACM/ICPC 之 Dinic+枚举最小割点集(可做模板)(POJ1815)
		
最小割的好题,可用作模板. //Dinic+枚举字典序最小的最小割点集 //Time:1032Ms Memory:1492K #include<iostream> #include< ...
 - poj  2299 归并排序求逆序数  (可做模板)
		
Time Limit: 7000MS Memory Limit: 65536K Total Submissions: 48077 Accepted: 17533 Description In ...
 - LOJ-1308-Ant network(蚂蚁的网络)-求割点分隔开的子图个数及乘积
		
网上的题解大都模糊,我可能写的也比较模糊吧,讲究看看. 大致题意: 原图没有一个割点时,特殊考虑,至少ans1=2个通风井,方案数n*(n-1)/2; 原图上有多个割点时,每个(由割点限制成几部分的) ...
 - poj 1523Tarjan算法的含义——求取割点可以分出的连通分量的个数
		
poj 1523Tarjan算法的含义——求取割点可以分出的连通分量的个数 题目大意:如题目所示 给你一些关系图——连通图,想要问你有没有个节点,损坏后,可以生成几个互相独立的网络(也就是连通分量), ...
 - tarkjan求无向图割点模板
		
#include<bits/stdc++.h> using namespace std; typedef long long ll; int n,m; ; ; struct node { ...
 - tarjan求割边割点
		
tarjan求割边割点 内容及代码来自http://m.blog.csdn.net/article/details?id=51984469 割边:在连通图中,删除了连通图的某条边后,图不再连通.这样的 ...
 - AtCoder Beginner Contest 142【D题】【判断素数的模板+求一个数的因子的模板】
		
D - Disjoint Set of Common Divisors Problem Statement Given are positive integers AA and BB. Let us ...
 
随机推荐
- JavaScript模块化开发的那些事
			
模块化开发在编程开发中是一个非常重要的概念,一个优秀的模块化项目的后期维护成本可以大大降低.本文主要介绍了JavaScript模块化开发的那些事,文中通过一个小故事比较直观地阐述了模块化开发的过程. ...
 - IOS tableView 去除分割线 和 不允许选中表格cell
			
//去除分割线 self.tableView.backgroundColor=[UIColor colorWithRed:///255.0 alpha:1.0]; self.tableView.sep ...
 - Aizu 0033 Ball(dfs,贪心)
			
日文题面...题意:是把一连串的有编号的球往左或者往右边放.问能不能两边都升序. 记录左边和右边最上面的球编号大小,没有就-1,dfs往能放的上面放. #include<bits/stdc++. ...
 - 2018.2.7  css 的一些方法盒子模型
			
css 的一些方法 1.盒模型代码简写 盒模型的外边距(margin).内边距(padding)和边框(border)设置上下左右四个方向的边距是按照顺时针方向设置的:上右下左.具体应用在margin ...
 - TypeScript 编译选项
			
编译选项 选项 类型 默认值 描述 --allowJs boolean false 允许编译javascript文件. --allowSyntheticDefaultImports boolean m ...
 - python序列化(数据本地存放持久性存储)和反序列化
			
http://blog.csdn.net/uestcyao/article/details/7874817 #读取图片并存储为矩阵 from scipy.misc import imread im = ...
 - MySQL - RIGHT JOIN
			
RIGHT JOIN 关键字 RIGHT JOIN 关键字会右表 (table_name2) 那里返回所有的行,即使在左表 (table_name1) 中没有匹配的行. RIGHT JOIN 关键字语 ...
 - [mysql] Can't read from messagefile
			
系统:windows 重启mysql服务出现 Server] Can't read from messagefile 等错误时候, 应先执行 mysqld --initialize-insecure ...
 - 项目实战14.1—ELK 企业内部日志分析系统
			
本文收录在Linux运维企业架构实战系列 一.els.elk 的介绍 1.els,elk els:ElasticSearch,Logstash,Kibana,Beats elk:ElasticSear ...
 - docker安装后无法启动问题
			
问题报错: Error starting daemon: Error initializing network controller: list bridge addresses failed: no ...