力扣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;
    }
};
相关推荐
梵刹古音1 分钟前
【C语言】 指针与数据结构操作
c语言·数据结构·算法
VT.馒头7 分钟前
【力扣】2695. 包装数组
前端·javascript·算法·leetcode·职场和发展·typescript
CoderCodingNo2 小时前
【GESP】C++五级练习题 luogu-P1865 A % B Problem
开发语言·c++·算法
大闲在人2 小时前
7. 供应链与制造过程术语:“周期时间”
算法·供应链管理·智能制造·工业工程
小熳芋2 小时前
443. 压缩字符串-python-双指针
算法
Charlie_lll2 小时前
力扣解题-移动零
后端·算法·leetcode
chaser&upper2 小时前
矩阵革命:在 AtomGit 解码 CANN ops-nn 如何构建 AIGC 的“线性基石”
程序人生·算法
weixin_499771552 小时前
C++中的组合模式
开发语言·c++·算法
iAkuya3 小时前
(leetcode)力扣100 62N皇后问题 (普通回溯(使用set存储),位运算回溯)
算法·leetcode·职场和发展
近津薪荼3 小时前
dfs专题5——(二叉搜索树中第 K 小的元素)
c++·学习·算法·深度优先