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

邯郸网站建设做公司称心的赣州网站建设

邯郸网站建设做公司,称心的赣州网站建设,餐饮会员管理系统,做网站找我图片我们对每个连通块进行dfs,在深搜的过程中,定义两个变量v,e.其中v表示该连通图的节点数量,e表示该连通图中边的数量的两倍。为什么是两倍呢?因为我们针对某个节点进行dfs的过程中,我们让e加上这个节点所连边的数量&…

我们对每个连通块进行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.dtcms.com/wzjs/597137.html

相关文章:

  • 南京网站制作哪家好广州网站营销seo
  • o2o商城网站建设可视化网站开发工具有哪些
  • 单片机做网站wordpress会员卡系统
  • 时光轴 网站杭州网站设计公司有哪些
  • 网站开发前景好吗网页设计宣传推广方案
  • 网站建设中数据字典百度云wordpress教程
  • ssh课程网站开发沧州建设网站的公司
  • 网络优化策划书福州网站设计十年乐云seo
  • 招聘做牙技工的网站佛山网站建设seo优化
  • 建设网站的页面设计温州捷创网站建设
  • 注册电气师在哪个网站做变更随州网站seo诊断
  • 网站 通管局 报备西安电子商务网站
  • 网站建设 中企动力南通安徽亳州建设厅网站
  • 广东网站设计工具建网站的公司
  • 网站建设品牌公司哪家好WordPress直接调用头像地址
  • 内蒙古住房与城乡建设厅网站吉林seo基础
  • 成都专业网站建设机构重庆短视频seo优化推荐
  • server2012做网站frontpage做网站
  • 网站开发主要学些什么网站建设中 下载
  • 网站建设国内外研究现况网络广告投放形式
  • p2p电影网站开发品牌网络营销案例
  • 360网站推广登录唐山路北网站建设
  • 北京网站高端定制商务公司网站建设
  • 开发网站开源免费聊天app开发源码
  • 【郑州网站建设】建造网站需要多少钱
  • 德州中文网站建设wordpress移动客户端
  • 电子商务网站建设规划开题报告网站开发php和ui
  • 盐城市滨海县建设局网站企业建站系统免费
  • 网站建设公司网页自己制作头像的软件
  • WordPress挂在虚拟站点巩义专业网站建设公司首选