文章

26

粉丝

407

获赞

0

访问

335.5k

头像
Tarjan求有向图连通分量
经验总结
发布于2020年4月17日 22:13
阅读数 11.7k

 


time = 1; dfn[N] = { 0 }, low[N] = { 0 };
void dfs(int x){
	stack.push(x);
	dfn[x] = low[x] = time++;
	for (int y = 0; y < n; v++){
		if (g[x][y]){
			if (dfn[y] == 0){
				dfs(y);
				low[x] = min(low[x], low[y]);
			}
		}
		else if (y in stack){
			low[x] = min(low[x], low[y]);
		}
	}
}
main(){
	for (int x = 0; x < n; x++){
		if (dfn[x] == 0){
			dfs(x);
		}
	}
}
#include<iostream>
#include<algorithm>
using namespace std;
const int N = 110;
const int M = 510;
int h[N], e[M], next_pos[M], idx;
int belong[N], stack_arr[N], stack_top, is_in_stack[N], dfn[N], low[N], bent_num, time;
int n, m;
void add(int a, int b){
	e[++idx] = b;
	next_pos[idx] = h[a];
	h[a] = idx;
}
void tarjan(int x){
	dfn[x] = low[x] = ++time;
	stack_arr[++stack_top] = x;
	is_in_stack[x] = 1;
	for (int i = h[x]; i; i = next_pos[i]){
		int j = e[i];
		if (!dfn[j]){
			tarjan(j);
			low[x] = min(low[x], low[j]);
		}
		else if (is_in_st...
登录查看完整内容


登录后发布评论

暂无评论,来抢沙发