UVA247- Calling Circles(有向图的强连通分量)
题意: 给定一张有向图。找出全部强连通分量,并输出。
思路:有向图的强连通分量用Tarjan算法,然后用map映射,便于输出,注意输出格式。
代码:
#include <iostream>
#include <cstdio>
#include <cstring>
#include <map>
#include <algorithm> using namespace std; const int MAXN = 2000;
const int MAXM = 50000; struct Edge{
int to, next;
}edge[MAXM]; int head[MAXN], tot;
int Low[MAXN], DFN[MAXN], Stack[MAXN], Belong[MAXN];
int Index, top;
int scc;
bool Instack[MAXN];
int num[MAXN];
int n, m, cnt;
map<string, int> sTon;
map<int, string> nTos; void init() {
tot = cnt = 0;
memset(head, -1, sizeof(head));
sTon.clear();
nTos.clear();
} void addedge(int u, int v) {
edge[tot].to = v;
edge[tot].next = head[u];
head[u] = tot++;
} void Tarjan(int u) {
int v;
Low[u] = DFN[u] = ++Index;
Stack[top++] = u;
Instack[u] = true;
for (int i = head[u]; i != -1; i = edge[i].next) {
v = edge[i].to;
if (!DFN[v]) {
Tarjan(v);
if (Low[u] > Low[v]) Low[u] = Low[v]; }
else if (Instack[v] && Low[u] > DFN[v])
Low[u] = DFN[v];
}
if (Low[u] == DFN[u]) {
scc++;
do {
v = Stack[--top];
Instack[v] = false;
Belong[v] = scc;
num[scc]++;
} while (v != u);
}
} void solve() {
memset(Low, 0, sizeof(Low));
memset(DFN, 0, sizeof(DFN));
memset(num, 0, sizeof(num));
memset(Belong, 0, sizeof(Belong));
memset(Stack, 0, sizeof(Stack));
memset(Instack, false, sizeof(Instack));
Index = scc = top = 0;
for (int i = 1; i <= n; i++)
if (!DFN[i])
Tarjan(i);
} int main() {
int t = 0;
while (scanf("%d%d", &n, &m)) {
if (n == 0 && m == 0) break;
init();
string s1, s2;
for (int i = 0; i < m; i++) {
cin >> s1 >> s2;
if (sTon.find(s1) == sTon.end()) {
cnt++;
sTon[s1] = cnt;
nTos[cnt] = s1;
}
if (sTon.find(s2) == sTon.end()) {
cnt++;
sTon[s2] = cnt;
nTos[cnt] = s2;
}
addedge(sTon[s1], sTon[s2]);
} if (t) printf("\n");
printf("Calling circles for data set %d:\n", ++t);
solve();
for (int i = 1; i <= scc; i++) {
int flag = 0;
for (int u = 1; u <= n; u++) {
if (Belong[u] == i) {
if (!flag) {
cout << nTos[u];
flag = 1;
}
else cout << ", " << nTos[u];
}
}
printf("\n");
}
}
return 0;
}
UVA247- Calling Circles(有向图的强连通分量)的更多相关文章
- 『Tarjan算法 有向图的强连通分量』
		
有向图的强连通分量 定义:在有向图\(G\)中,如果两个顶点\(v_i,v_j\)间\((v_i>v_j)\)有一条从\(v_i\)到\(v_j\)的有向路径,同时还有一条从\(v_j\)到\( ...
 - 图->连通性->有向图的强连通分量
		
文字描述 有向图强连通分量的定义:在有向图G中,如果两个顶点vi,vj间(vi>vj)有一条从vi到vj的有向路径,同时还有一条从vj到vi的有向路径,则称两个顶点强连通(strongly co ...
 - DFS的运用(二分图判定、无向图的割顶和桥,双连通分量,有向图的强连通分量)
		
一.dfs框架: vector<int>G[maxn]; //存图 int vis[maxn]; //节点访问标记 void dfs(int u) { vis[u] = ; PREVISI ...
 - uva11324 有向图的强连通分量+记忆化dp
		
给一张有向图G, 求一个结点数最大的结点集,使得该结点集中任意两个结点u和v满足,要么u可以到达v, 要么v可以到达u(u和v相互可达也可以). 因为整张图可能存在环路,所以不好使用dp直接做,先采用 ...
 - 图论-求有向图的强连通分量(Kosaraju算法)
		
求有向图的强连通分量 Kosaraju算法可以求出有向图中的强连通分量个数,并且对分属于不同强连通分量的点进行标记. (1) 第一次对图G进行DFS遍历,并在遍历过程中,记录每一个点的退出顺序 ...
 - Kosaraju算法 有向图的强连通分量
		
有向图的强连通分量即,在有向图G中,如果两个顶点间至少存在一条路径,称两个顶点强连通(strongly connected).如果有向图G的每两个顶点都强连通,称G是一个强连通图.非强连通图有向图的极 ...
 - [有向图的强连通分量][Tarjan算法]
		
https://www.byvoid.com/blog/scc-tarjan 主要思想 Tarjan算法是基于对图深度优先搜索的算法,每个强连通分量为搜索树中的一棵子树.搜索时,把当前搜索树中未处理的 ...
 - 【数据结构】DFS求有向图的强连通分量
		
用十字链表结构写的,根据数据结构书上的描述和自己的理解实现.但理解的不透彻,所以不知道有没有错误.但实验了几个都ok. #include <iostream> #include <v ...
 - POJ 1236 Network of Schools (有向图的强连通分量)
		
Network of Schools Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 9073 Accepted: 359 ...
 
随机推荐
- WebSphere之wasprofile.sh使用
			
概要文件(profile) 6.0版本以后才有profile,目的是将用户数据和was本身的文件分开,这样可以定义多个profile,每个profile相当于一个用户,相当于提供了多用户的支持. pr ...
 - 理清fineuploader无刷新上传的一些事
			
1.fineuploader是一款不依赖与jquery的异步无刷新上传组件,fineuploader采用ajax方式实现对文件上传,返回值都是以json的格式,对后台服务器操作和前端dom对象一些操作 ...
 - (转)wcf client与webservice通信(-)只修改配置文件而改变服务端
			
http://www.cnblogs.com/yiyisawa/archive/2008/12/16/1356191.html 问题: 假设有一个大型系统新版本使用wcf 作为服务端,生成wcf cl ...
 - ASP.net(C#)利用SQL Server实现注册和登陆功能
			
说说我现在吧,楼主现在从事的事IT行业,主攻DotNet技术:当然这次上博客园我也是有备而来,所有再次奉献鄙人拙作,以飨诸位,望诸位不吝赐教. 世界上大多数的工作都是熟练性的工种,编程也不例外,做久了 ...
 - TOJ3596 二维背包
			
3596. Watch The Movie Time Limit: 2.0 Seconds Memory Limit: 65536KTotal Runs: 424 Accepted Run ...
 - hdu 素数环
			
算法:搜索 题意:相邻的两个数之和是素数,别忘了最后一个,和第一个 Problem Description A ring is compose of n circles as shown in dia ...
 - I/O复用-epoll模型
			
epoll函数 epoll函数的使用与select.poll上有很大的差异. epoll使用一组函数来完成任务,而不是单个函数. epoll把用户关心的文件描述符上的事件放在内核里的一个事件表中,从而 ...
 - Oracle11g R2学习系列 之四Maven+Struts+Spring实验
			
今天试一下Java调用Oracle来看一下.会不会也如昨天实验的一样坑呢?由于我对于Java也接触的不多,所以不打算直接使用该收提供的实验文档,而是自己利用Maven+Struts+Spring来自己 ...
 - [Apache系列]怎样在windows下配置apache vhost
			
找到你的Apache安装目录,下图为小编的Apache安装的目录 2 点击conf文件夹 进入配置目录,找到httpd.conf 文件, 3 打开httpd.conf 文件,如图, 找到地475行, ...
 - linux上安装apache以及httpd.conf基本配置
			
1.yum安装apache #yum install httpd -y 2.随系统自启动 #chkconfig httpd on 3.开启apache #service httpd start PS: ...