传送门

思维!重要的是思维!

题目让删边,然而并查集不好删边(并!查!集!啊)

我们离线处理,从后往前添边,这样并查集就可以用了。

用并查集维护连通块个数即可。

——代码

  1. #include <cstdio>
  2. #include <cstring>
  3. #include <iostream>
  4. #define N 400001
  5.  
  6. int n, m, k, ans, cnt;
  7. int head[N], to[N << ], next[N << ], f[N], a[N], anslist[N];
  8. bool vis[N];
  9.  
  10. inline int read()
  11. {
  12. int x = , f = ;
  13. char ch = getchar();
  14. for(; !isdigit(ch); ch = getchar()) if(ch == '-') f = -;
  15. for(; isdigit(ch); ch = getchar()) x = (x << ) + (x << ) + ch - '';
  16. return x * f;
  17. }
  18.  
  19. inline void add(int x, int y)
  20. {
  21. to[cnt] = y;
  22. next[cnt] = head[x];
  23. head[x] = cnt++;
  24. }
  25.  
  26. inline int find(int x)
  27. {
  28. return x == f[x] ? x : f[x] = find(f[x]);
  29. }
  30.  
  31. int main()
  32. {
  33. int i, j, x, y, fx, fy;
  34. n = read();
  35. m = read();
  36. memset(head, -, sizeof(head));
  37. for(i = ; i <= m; i++)
  38. {
  39. x = read();
  40. y = read();
  41. add(x, y);
  42. add(y, x);
  43. }
  44. k = read();
  45. for(i = ; i <= k; i++)
  46. {
  47. a[i] = read();
  48. vis[a[i]] = ;
  49. }
  50. ans = n - k;
  51. for(i = ; i < n; i++) f[i] = i;
  52. for(x = ; x < n; x++)
  53. {
  54. if(vis[x]) continue;
  55. for(i = head[x]; i ^ -; i = next[i])
  56. {
  57. y = to[i];
  58. if(vis[y]) continue;
  59. fx = find(x);
  60. fy = find(y);
  61. if(fx ^ fy) f[fx] = fy, ans--;
  62. }
  63. }
  64. anslist[k] = ans;
  65. for(i = k; i >= ; i--)
  66. {
  67. x = a[i];
  68. ans++;
  69. for(j = head[x]; j ^ -; j = next[j])
  70. {
  71. y = to[j];
  72. if(vis[y]) continue;
  73. fx = find(x);
  74. fy = find(y);
  75. if(fx ^ fy) f[fx] = fy, ans--;
  76. }
  77. vis[x] = ;
  78. anslist[i - ] = ans;
  79. }
  80. for(i = ; i <= k; i++) printf("%d\n", anslist[i]);
  81. return ;
  82. }

总结:有些需要删边询问连通性之类的题目,可以试试从后往前用并查集添边。

   逆向思维很重要!正着不方便就反着来。

[luoguP1197] [JSOI2008]星球大战(并查集)的更多相关文章

  1. 洛谷P1197 [JSOI2008] 星球大战 [并查集]

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

  2. JSOI2008 星球大战 [并查集]

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

  3. P1197 [JSOI2008]星球大战[并查集+图论]

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

  4. P1197 [JSOI2008]星球大战 并查集 反向

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

  5. [bzoj1015][JSOI2008]星球大战——并查集+离线处理

    题解 给定一张图,支持删点和询问连通块个数 按操作顺序处理的话要在删除点的同时维护图的形态(即图具体的连边情况),这是几乎不可做的 我们发现,这道题可以先读入操作,把没删的点的边先连上,然后再倒序处理 ...

  6. 洛谷 P1197 [JSOI2008]星球大战——并查集

    先上一波题目 https://www.luogu.org/problem/P1197 很明显删除的操作并不好处理 那么我们可以考虑把删边变成加边 只需要一波时间倒流就可以解决拉 储存删边顺序倒过来加边 ...

  7. BZOJ_1015_星球大战_[JSOI2008]_(并查集)

    描述 http://www.lydsy.com/JudgeOnline/problem.php?id=1015 n 个点,被 m 条边相连.进行k次删点操作,问第一次操作前和每次操作后的集合数(直接或 ...

  8. 【BZOJ1015】【JSOI2008】星球大战 并查集

    题目大意 给你一张\(n\)个点\(m\)条边的无向图,有\(q\)次操作,每次删掉一个点以及和这个点相邻的边,求最开始和每次删完点后的连通块个数. \(q\leq n\leq 400000,m\le ...

  9. 【JSOI2008】星球大战 并查集

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

随机推荐

  1. bzoj4889

    http://www.lydsy.com/JudgeOnline/problem.php?id=4889 人傻常数大 bzoj上跑不过 洛谷上能过两到三个点 我写的是树套树啊 怎么跑的比分块还慢 每次 ...

  2. Grunt环境搭建及使用

    jQuery在使用grunt,bootstrap在使用grunt,百度UEditor在使用grunt,你没有理由不学.不用! 1. 前言 各位web前端开发人员,如果你现在还不知道grunt或者听说过 ...

  3. HyperLedger Fabric部署与链码解读

    1.Fabric简介 Fabric是超级账本中的一个项目,用以推进区块链技术.和其他区块链类似,它也有一个账本,使用智能合约,且是一个参与者可以分别管理自身交易的系统.它是一个联盟链.Fabric与其 ...

  4. 关于二分查找 使用 lower_bound

    在寻找单调递增最长自序列 , 的时候能不能确认出来哪个是单调递增最长自序列  ?  我的想法是 if(location>=num) dp[location]=b; 这样的 , 基于http:// ...

  5. HTML--使用mailto在网页中链接Email地址

    <a>标签还有一个作用是可以链接Email地址,使用mailto能让访问者便捷向网站管理者发送电子邮件.我们还可以利用mailto做许多其它事情.下面一一进行讲解,请看详细图示: 注意:如 ...

  6. android:autoLink

    android:autoLink 显示URL链接 TextView识别链接的方式有两种,一种是自动识别链接和HTML解析链接 1)自动识别链接 <!-- android:autoLink=&qu ...

  7. 灾备还原之gitlab

    灾备还原之gitlab 备份情景:服务器A架设了gitlab,定期通过duplicity发送加密备份给B服务器,现在由于某种情况生产机器A完全无法访问(主机商跑路?硬盘冒烟?服务器BOOM了?),本地 ...

  8. ACM_Cipher(异或运算)

    Cipher Time Limit: 2000/1000ms (Java/Others) Problem Description: 只剩两个小时就要正式开始第一次月赛了,大四师兄决定还是来出一道,找点 ...

  9. mysql视图的操作

    一.创建视图的语法形式 CREATE VIEW view_name AS 查询语句 ; 使用视图 SELECT * FROM view_name ; 二.创建各种视图 1.封装实现查询常量语句的视图, ...

  10. mysql zip版本如何安装

    1.下载mysqlzip包并解压到D:\javadeveloper\mysql-5.6.24-winx642.配置环境变量在path中添加路径 D:\javadeveloper\mysql-5.6.2 ...