图论 判断图是否带环的三种方法 | 有向图 and 无向图

本文介绍了四种方法来判断图是否包含环:针对无向图,通过DFS深度优先搜索和并查集策略;对于有向图,则利用DFS和拓扑排序,包括链式前向星结合优先队列以及邻接矩阵配合优先队列的实现方式。
摘要由CSDN通过智能技术生成




无向图

1> dfs


2> 并查集

class DisjointSet {
    
public:	
    static const int MAXN = 1e3+100;
    int n;
	int root[MAXN];
    DisjointSet( ) {
    };
    DisjointSet( int _n ) : n(_n) {
    };
	void ini ( int n ) {
   
		this->n = n;
		for ( int i = 1; i <= n; ++i ) root[i] = i;
	}
	int get ( int x ) {
   
		return root[x]==x ? x : root[x]=get( root[x] );
	}
	bool merge ( int x, int y ) {
   
		int rx = get( x ), ry = get( y );
		if ( rx==ry ) return false;
		root[ry] = rx; return true;
	}
}ds;




有向图

1> dfs


2> 拓扑排序

1. 链式前向星 + 优先队列

class TopologicalSort_AdjicencyList {
    
public:
	static const int
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值