力扣2685(dfs)

我们对每个连通块进行dfs,在深搜的过程中,定义两个变量v,e.其中v表示该连通图的节点数量,e表示该连通图中边的数量的两倍。为什么是两倍呢?因为我们针对某个节点进行dfs的过程中,我们让e加上这个节点所连边的数量,如此一来,每条边都会被重复计算一遍。

最后,我们看e是否等于v*(v-1)。如果是,那么完全连通分量的数量就+1,否则不变。

为什么是v*(v-1)?因为在完全连通分量中,边的数量为v*(v-1)/2(相当于在v个节点中选择2个的组合数),而每条边都被重复计算了一遍,所以要乘2.

代码如下:

cpp 复制代码
class Solution
{
public:
    int v = 0, e = 0;
    void dfs(vector<vector<int>>& graph, vector<bool>& vis, int x)
    {
        vis[x] = true;
        v++;//遇到了新的节点,v要+1
        e += graph[x].size();//边数要加上该节点连接的边数量(这里会重复计算)
        for (int k : graph[x])
        {
            if (!vis[k])
            {
                dfs(graph, vis, k);
            }
        }
    }
    int countCompleteComponents(int n, vector<vector<int>>& edges)
    {
        //建图
        vector<vector<int>>graph(n);
        for (auto& e : edges)
        {
            graph[e[0]].push_back(e[1]);
            graph[e[1]].push_back(e[0]);
        }

        v = 0, e = 0;//重置

        int ans = 0;

        vector<bool>vis(n, false);
        for (int i = 0; i < n; i++)//对每个结点开始深搜
        {
            if (!vis[i])
            {
                v = 0, e = 0;//对每个连通图进行深搜之前,需要重置数据
                dfs(graph, vis, i);
                ans += (e == v * (v - 1));
            }
        }
        return ans;
    }
};
相关推荐
AndrewHZ1 小时前
【图像处理基石】什么是油画感?
图像处理·人工智能·算法·图像压缩·视频处理·超分辨率·去噪算法
.格子衫.1 小时前
015枚举之滑动窗口——算法备赛
数据结构·算法
J先生x2 小时前
【IP101】图像处理进阶:从直方图均衡化到伽马变换,全面掌握图像增强技术
图像处理·人工智能·学习·算法·计算机视觉
爱coding的橙子4 小时前
每日算法刷题 Day3 5.11:leetcode数组2道题,用时1h(有点慢)
算法·leetcode
Dream it possible!8 小时前
LeetCode 热题 100_只出现一次的数字(96_136_简单_C++)(哈希表;哈希集合;排序+遍历;位运算)
c++·leetcode·位运算·哈希表·哈希集合
?abc!9 小时前
缓存(5):常见 缓存数据淘汰算法/缓存清空策略
java·算法·缓存
BioRunYiXue9 小时前
一文了解氨基酸的分类、代谢和应用
人工智能·深度学习·算法·机器学习·分类·数据挖掘·代谢组学
jiunian_cn10 小时前
【c++】异常详解
java·开发语言·数据结构·c++·算法·visual studio
工藤新一¹11 小时前
蓝桥杯算法题 -蛇形矩阵(方向向量)
c++·算法·矩阵·蓝桥杯·方向向量
Levin__NLP_CV_AIGC11 小时前
解决pip安装PyPI默认源速度慢
算法·pip