poj1523求割点以及割后连通分量数tarjan算法应用
无向图,双向通道即可,tarjan算法简单应用。点u是割点,条件1:u是dfs树根,则u至少有2个孩子结点。||条件2:u不是根,dfn[u]=<low[v],v是u的孩子结点,而且每个这样的v,对应一个块(割了该点后),则u是割点。不求强连通分量不需要栈。
#include<iostream>
#include<cstdio>
#include<vector> //用这个做链表,保存边,方便。
#include<cstring>
using namespace std;
int subnet[1000]; //割点i有subnet[i]+1个子网络
int dfn[1001];
int low[1001];
int visited[1001]; //标记访问
int time=0; //时间戳
int son=0; //DFS树根的孩子结点个数,割点判断条件之一
int min(int a,int b)
{
if(a<=b)return a;
return b;
}
void tarjan(int u,vector<vector<int> > v) //dfs
{
dfn[u]=low[u]=++time;
for(int i=0;i<v[u].size();i++) //遍历U的所有边
{
if(visited[v[u][i]]==0)
{
visited[v[u][i]]=1;
tarjan(v[u][i],v);
low[u]=min(low[u],low[v[u][i]]); //更新1
//回溯时判断
if(u==1) //割点判断条件1
{
son++;
}
else if(dfn[u]<=low[v[u][i]]) //非DFS树根 割点判断条件2
{
subnet[u]++; //每个U的子孩子对应一个块(u同时属于这些块)
}
}
else
{
low[u]=min(dfn[v[u][i]],low[u]); //更新2
}
}
}
int main()
{
int a,b;
int tcase=0;
while(~scanf("%d",&a)&&a)
{
scanf("%d",&b);
tcase++;
memset(subnet,0,sizeof(subnet));
memset(dfn,0,sizeof(dfn));
memset(low,0,sizeof(low));
memset(visited,0,sizeof(visited));
vector<vector<int> >v(1001);
v[a].push_back(b);
v[b].push_back(a);
while(~scanf("%d",&a)&&a)
{
scanf("%d",&b);
v[a].push_back(b);
v[b].push_back(a);
}
time=0;son=0;
visited[1]=1;
tarjan(1,v); //将顶点1作为入口(树根)。
printf("Network #%d\n",tcase);
int count=0;
if(son>1)
{
printf(" SPF node 1 leaves %d subnets\n",son);
count++;
}
for(int i=0;i<1001;i++)
if(subnet[i]!=0)
{printf(" SPF node %d leaves %d subnets\n",i,subnet[i]+1);count++;}
if(count==0)
printf(" No SPF nodes\n");
printf("\n");
}
}
poj1523求割点以及割后连通分量数tarjan算法应用的更多相关文章
- UESTC 900 方老师炸弹 --Tarjan求割点及删点后连通分量数
Tarjan算法. 1.若u为根,且度大于1,则为割点 2.若u不为根,如果low[v]>=dfn[u],则u为割点(出现重边时可能导致等号,要判重边) 3.若low[v]>dfn[u], ...
- hdu 4587 2013南京邀请赛B题/ / 求割点后连通分量数变形。
题意:求一个无向图的,去掉两个不同的点后最多有几个连通分量. 思路:枚举每个点,假设去掉该点,然后对图求割点后连通分量数,更新最大的即可.算法相对简单,但是注意几个细节: 1:原图可能不连通. 2:有 ...
- 【转】BYV--有向图强连通分量的Tarjan算法
转自beyond the void 的博客: https://www.byvoid.com/zhs/blog/scc-tarjan 注:红色为标注部分 [有向图强连通分量] 在有向图G中,如果两个顶点 ...
- poj1523 求割点 tarjan
SPF Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 7678 Accepted: 3489 Description C ...
- 洛谷 P3388 【模板】割点(割顶)(Tarjan)
题目链接 https://www.luogu.org/problemnew/show/P3388 模板题 解题思路 什么是割点? 怎样求割点? dfn :即时间戳,一张图的dfs序(dfs遍历时出现的 ...
- [学习笔记]连通分量与Tarjan算法
目录 强连通分量 求割点 求桥 点双连通分量 模板题 Go around the Labyrinth 所以Tarjan到底怎么读 强连通分量 基本概念 强连通 如果两个顶点可以相互通达,则称两个顶点强 ...
- 求LCA最近公共祖先的离线Tarjan算法_C++
这个Tarjan算法是求LCA的算法,不是那个强连通图的 它是 离线 算法,时间复杂度是 O(m+n),m 是询问数,n 是节点数 它的优点是比在线算法好写很多 不过有些题目是强制在线的,此类离线算法 ...
- mysql语句求按字段分组后组数是多少
select count(distinct ID) from table Thinkphp CURD写 $count = $model->where($where)->count('dis ...
- (转)Tarjan应用:求割点/桥/缩点/强连通分量/双连通分量/LCA(最近公共祖先)
基本概念: 1.割点:若删掉某点后,原连通图分裂为多个子图,则称该点为割点. 2.割点集合:在一个无向连通图中,如果有一个顶点集合,删除这个顶点集合,以及这个集合中所有顶点相关联的边以后,原图变成多个 ...
随机推荐
- Ubuntu系统下配置PHP支持SQLServer 2005
最近在做一个项目,该项目的数据库是微软公司的的SQLserver ,数据库安装在另一台windows服务器上,而项目却部署在ubuntu server上.那么这样就会涉及到项目在linux上如何链接S ...
- Django创建第一个应用
一.创建第一个应用,并在settings.py中添加. python manage.py startapp article 二.创建第一个模型 class Article(models.Model): ...
- JavaScript-基础类型和运算符
JavaScript-基础类型和运算符 P02.稍微了解 1.js代码需要编写到script标签中 <script type="text/javascript"> 此处 ...
- hql语法001
1. import java.util.List; import org.hibernate.*; import org.junit.Test; import cn.jbit.hibernatedem ...
- 数组排序 sort
数组排序 this.dataShow = this.data.sort((a, b) => { return parseInt(a[this.innerOrderBy]) - parseInt( ...
- 树状数组 || POJ 2352 Stars
Astronomers often examine star maps where stars are represented by points on a plane and each star h ...
- PHP10 错误和异常处理
学习要点 修改错误报告级别 写错误日志 异常处理实现 自定义异常 捕获多路异常 错误处理 定义 错误:开发过程中的失误.用户操作引起的错误. 错误产生原因 语法错误:开发环境提示,未修正则脚本无法 ...
- No-6.用户权限相关命令
用户权限相关命令 目标 用户 和 权限 的基本概念 用户管理 终端命令 组管理 终端命令 修改权限 终端命令 01. 用户 和 权限 的基本概念 1.1 基本概念 用户 是 Linux 系统工作中重要 ...
- ES5的数组方法
参考:https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array Array.prot ...
- ubuntu卸载编译安装的软件
cd 源代码目录 make clean ./configure make make uninstall