当前位置: 首页 > news >正文

力扣2685(dfs)

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

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

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

代码如下:
 

class Solution
{
public:int v = 0, e = 0;void dfs(vector<vector<int>>& graph, vector<bool>& vis, int x){vis[x] = true;v++;//遇到了新的节点,v要+1e += 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;}
};

相关文章:

  • 什么是管理思维?
  • APP嵌入WebView实现中国地图分布图
  • Mediatek Android13 设置Launcher
  • UML概览
  • Spark-Streaming简介 核心编程
  • 在线视频转 AVI 的便捷之选,便捷操作,无需下载软件,在线使用
  • 信息系统项目管理师_第十二章 项目风险管理
  • 复盘20250422
  • 3d打印机设备厂家|casaim打印建筑楼盘模型
  • 探索 Linux 路由表及 route 命令的奥秘
  • 每日OJ_牛客_AOE还是单体?_贪心_C++_Java
  • Spring事件机制,如何使用Spring事件监听器
  • ROS 2开发中的目录哲学:源码与产物的共生关系
  • RockChip Android14 修改LCD背光最大值
  • 云账号安全事件应急响应指南:应对来自中国IP的异常访问
  • STM32 外部中断
  • iPaaS+AI:企业数智化转型的“智能基座”与创新引擎
  • Unity 脚本使用(二)——UnityEngine.AI——NavMesh
  • Flink介绍——实时计算核心论文之Dataflow论文详解
  • 进阶篇 第 3 篇:经典永不落幕 - ARIMA 模型详解与实践
  • 视频·世界读书日|王弘治:信息轰炸也会让文化体力透支
  • “动漫短剧”值不值得做?
  • 谁为金子疯狂:有人贷款十万博两千,有人不敢再贸然囤货
  • 外交部:中方近日派出停火监督组赴缅,监督缅军和果敢同盟军停火
  • 这5种走路姿势,藏着疾病秘密,第2种你可能也有
  • 88岁罗马教皇方济各突然去世,遗嘱内容对外公布