当前位置: 首页 > 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;}
};

http://www.xdnf.cn/news/75889.html

相关文章:

  • 桌面我的电脑图标不见了怎么恢复 恢复方法指南
  • docker保存镜像到本地
  • 懒人一键搭建符号执行环境V5K3
  • 【VS Code】打开远程服务器Docker项目或文件夹
  • Dataway在Spring Boot中的引入以及使用教程
  • 【美化vim】
  • Element Plus表格组件深度解析:构建高性能企业级数据视图
  • 【C++ 类和数据抽象】构造函数
  • 智能体MCP 实现数据可视化分析
  • Java 安全:如何防止 SQL 注入与 XSS 攻击?
  • GAEA的技术优势:分层加密与去中心化数据治理
  • 《C++ 模板:泛型编程的核心》
  • 基于javaweb的SSM+Maven小区失物招领系统设计与实现(源码+文档+部署讲解)
  • 超越Dify工作流:如何通过修改QwenAgent的Function Call及ReAct方法实现对日期时间的高效意图识别
  • 【MySQL】005.MySQL表的约束(上)
  • 2011-2020年 上市公司彭博ESG综合得分、环境得分、​治理得分统计数据表
  • Ollama 实战手册
  • 软考软件设计师考试情况与大纲概述
  • 【C语言】初阶算法相关习题(一)
  • Docker 部署 PostgreSQL 数据库
  • 记录学习的第三十天
  • 20.4 显示数据库数据
  • Centos 、Linux 基础运维命令
  • 【程序员 NLP 入门】词嵌入 - 如何基于计数的方法表示文本? (★小白必会版★)
  • MacOS 10.15上能跑大语言模型吗?
  • 用Java实现简易区块链:从零开始的探索
  • Mongodb分布式文件存储数据库
  • 相对论大师-记录型正负性质BFS/图论-链表/数据结构
  • sqoop的参数及初体验
  • 【MCP Node.js SDK 全栈进阶指南】初级篇(1):MCP开发环境搭建详解