poj1523求割点以及割后连通分量数tarjan算法应用
2014-02-04 19:30
288 查看
无向图,双向通道即可,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算法应用
- POJ1523(tarjan割点后,连通分量有多少)
- poj1523 求割点 及 该割点 可以 把该图分成几个连通分量
- poj1523--C - SPF(连通分量,求割点)
- poj 1523 求无向图所有割点以及删除割点后连通分量个数 给出详细算法思路
- 模板_poj1523SPF_割点以及点连通分支
- 图论复习之强连通分量以及缩点—Tarjan算法
- hdu4635Strongly connected 【求最多加多少边仍不是强连通分量】
- Tarjan三大算法之强连通分量
- sdut 1488 数据结构实验:连通分量个数(并查集)
- 8连通、4连通的洪泛填充以及边界填…
- POJ 2236 Wireless Network 【并查集的简单应用 判断是否在同一连通分量】
- 有向图的强连通分量分解
- 数据结构实验:连通分量个数
- 重连通分量的求解
- Network of Schools POJ - 1236 tarjan强连通分量
- hdu1269 运用tarjan算法求有向图中强连通分量数目
- ccf之高速公路 求强连通分量问题
- Matlab 图像处理 形态学 腐蚀 膨胀 开闭运算 连通分量
- 二分图强连通分量 tarjan 模板