当前位置:   article > 正文

基环图 && 求联通块个数_cpp 构造图 求各联通块个数

cpp 构造图 求各联通块个数

          ------------------------------基环树------------------------------

前置知识

生成树:什么是生成树,生成树(生成森林)详解 (biancheng.net)​​​​​​ 

基环树:具有N个点N条边连通图

连通图必然存在生成树

基环树 

1.概念: 简单来说,基环树就是一个环上挂着一堆树。

2.两个性质(充要条件)

(1)连通图

(2)边数m=点数n

证明:

(1)必要性:一个基环树肯定是一个连通图(树是连通图,环是连通图)。我们断掉基环树环上的任意一条边,基环树就会成为一棵普通的树,树有m=n-1。

(2)充要性:由于性质(1)我们可知该图是一个连通图,连通图一定可以求一棵生成树,生成树有m=n-1,说明此时我们还有一条边没有用。因为这条没用的边无论加在生成树的任何地方,都只能构成一个环,所以该连通图一定是一基环树。

                                                                 (基环树)

应用:4216. 图中的环 - AcWing题库

思路:由性质判断该图是不是基环树,主要判断是不是一个连通图

1.并查集(连通块个数为1就是一个连通图)

  1. #include <iostream>
  2. #include <cstring>
  3. #include <algorithm>
  4. using namespace std;
  5. const int N = 1100;
  6. int n, m, pre[N];
  7. int find(int x)
  8. {
  9. if(x == pre[x]) return pre[x];
  10. return pre[x] = find(pre[x]);
  11. }
  12. int main()
  13. {
  14. cin >> n >> m;
  15. if(n != m) puts("NO");
  16. else
  17. {
  18. for(int i &
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/黑客灵魂/article/detail/800417
推荐阅读
相关标签
  

闽ICP备14008679号