题目链接

题意

对给定的一张图,求其补图的联通块个数及大小。

思路

参考 ww140142.

维护一个链表,里面存放未归入到任何一个连通块中的点,即有必要从其开始进行拓展的点。

对于每个这样的点,从它开始进行 \(bfs\),将未被拓展到的点加入队列,并从链表中删除。

注意:写法上有一点要注意, 在处理完一整个连通块之后,记录下下一个连通块中的第一个点之后,再将最初的 \(src\) 从链表中删除。若一开始便删除,则会造成链表脱节。

Code

  1. #include <bits/stdc++.h>
  2. #define maxn 200010
  3. using namespace std;
  4. typedef long long LL;
  5. int ne[maxn], tot, n, m, tag[maxn], l[maxn], r[maxn];
  6. struct Edge { int to, ne; }edge[maxn<<1];
  7. void add(int u, int v) {
  8. edge[tot] = {v, ne[u]};
  9. ne[u] = tot++;
  10. }
  11. vector<int> ans;
  12. void bfs(int src) {
  13. queue<int> q;
  14. q.push(src);
  15. int sz = 0;
  16. while (!q.empty()) {
  17. ++sz;
  18. int u = q.front(); q.pop();
  19. for (int i = ne[u]; ~i; i = edge[i].ne) {
  20. tag[edge[i].to] = u;
  21. }
  22. for (int i = r[0]; i <= n; i = r[i]) {
  23. if (i != src && tag[i] != u) {
  24. q.push(i); r[l[i]] = r[i]; l[r[i]] = l[i];
  25. }
  26. }
  27. }
  28. ans.push_back(sz);
  29. }
  30. int main() {
  31. memset(ne, -1, sizeof ne);
  32. scanf("%d%d", &n, &m);
  33. for (int i = 0; i < m; ++i) {
  34. int u, v;
  35. scanf("%d%d", &u, &v);
  36. add(u, v); add(v, u);
  37. }
  38. for (int i = 1; i <= n; ++i) r[i] = i+1, l[i] = i-1;
  39. r[0] = 1; l[n+1] = n;
  40. for (int i = r[0]; i <= n; ) {
  41. bfs(i);
  42. int temp = r[i];
  43. r[l[i]] = r[i], l[r[i]] = l[i];
  44. i = temp;
  45. }
  46. sort(ans.begin(), ans.end());
  47. printf("%d\n", ans.size());
  48. for (auto x : ans) printf("%d ", x); puts("");
  49. return 0;
  50. }

Codeforces 920E Connected Components? 补图连通块个数的更多相关文章

  1. 【BZOJ 1098】办公楼(补图连通块个数,Bfs)

    补图连通块个数这大概是一个套路吧,我之前没有见到过,想了好久都没有想出来QaQ 事实上这个做法本身就是一个朴素算法,但进行巧妙的实现,就可以分析出它的上界不会超过 $O(n + m)$. 接下来介绍一 ...

  2. [Codeforces 920E]Connected Components?

    Description 题库链接 给你一个 \(n\) 个点 \(m\) 条边的无向图,求其补图的连通块个数及各个连通块大小. \(1\leq n,m\leq 200000\) Solution 参考 ...

  3. P1197 [JSOI2008]星球大战 [删边求连通块个数]

    展开 题目描述 很久以前,在一个遥远的星系,一个黑暗的帝国靠着它的超级武器统治着整个星系. 某一天,凭着一个偶然的机遇,一支反抗军摧毁了帝国的超级武器,并攻下了星系中几乎所有的星球.这些星球通过特殊的 ...

  4. Codeforces E - Connected Components?

    E - Connected Components? 思路: 补图bfs,将未访问的点存进set里 代码: #include<bits/stdc++.h> using namespace s ...

  5. ZOJ 1709 Oil Deposits(dfs,连通块个数)

    Oil Deposits Time Limit: 2 Seconds      Memory Limit: 65536 KB The GeoSurvComp geologic survey compa ...

  6. CodeForces 292D Connected Components (并查集+YY)

    很有意思的一道并查集  题意:给你n个点(<=500个),m条边(<=10000),q(<=20000)个询问.对每个询问的两个值xi yi,表示在从m条边内删除[xi,yi]的边后 ...

  7. bzoj 1015 维护连通块个数,离线并查集

    水. /************************************************************** Problem: 1015 User: idy002 Langua ...

  8. DFS:POJ1562-Oil Deposits(求连通块个数)

    Oil Deposits Time Limit: 1000MS Memory Limit: 10000K Description The GeoSurvComp geologic survey com ...

  9. 求连通块个数 - BFS、DFS、并查集实现

    本文基于leetcode的200.岛屿数量(题目

随机推荐

  1. k8s的ingress资源简述

    ingress controller是独立与controller-manager的Ingress的主要作用是可以利用nginx,haproxy,envoy,traefik等负载均衡器来暴露集群内部服务 ...

  2. tp5查询

    TP5的EXP.批量查询.聚合查询等. <!--more--> //使用EXP条件表达式,表示后面是原生的SQL表达式 $result = Db::table('think_inno')- ...

  3. Python Map, Filter and Reduce

    所属网站分类: python基础 > 函数 作者:慧雅 原文链接: http://www.pythonheidong.com/blog/article/21/ 来源:python黑洞网 www. ...

  4. java+Mysql大数据的一些优化技巧

    众所周知,java在处理数据量比较大的时候,加载到内存必然会导致内存溢出,而在一些数据处理中我们不得不去处理海量数据,在做数据处理中,我们常见的手段是分解,压缩,并行,临时文件等方法; 例如,我们要将 ...

  5. GTF/GFF

  6. 11,scrapy框架持久化存储

    今日总结 基于终端指令的持久化存储 基于管道的持久化存储 今日详情 1.基于终端指令的持久化存储 保证爬虫文件的parse方法中有可迭代类型对象(通常为列表or字典)的返回,该返回值可以通过终端指令的 ...

  7. 批处理文件执行cmd命令

    @echo offstart "wumin" "C:\Windows\System32\cmd.exe" osk taskkill /f /im cmd.exe ...

  8. Linux程序编辑器习题汇总

    简答题部分: 1.我用vi开启某个档案后,要在第34行向右移动15个字符,应该在一般模式中下达什么指令? (1)先按下34G到34行:(2)再按下[l5+向右键],或[l5l]亦可! 2.在vi开启的 ...

  9. Xmanager用法(export DISPLAY=客户端IP:0.0)

    1.在用户的目录下找到文件.bash_profile或profile,用vi对其进行编辑.加入下列命令行: DISPLAY=192.168.88.71:0.0;export DISPLAY 2.如果只 ...

  10. jmeter快捷键

    快捷键 功能 备注 Ctrl + C 复制 可复制组件 Ctrl + V 粘贴 可粘贴组件 Ctrl + Shift + C 复制粘贴当前组件到下一行   Ctrl + R 运行测试计划   Ctrl ...