Envy

感觉这种最小生成树上的啥题都差不多的解法。。

  1. #include<bits/stdc++.h>
  2. #define LL long long
  3. #define fi first
  4. #define se second
  5. #define mk make_pair
  6. #define PLL pair<LL, LL>
  7. #define PLI pair<LL, int>
  8. #define PII pair<int, int>
  9. #define SZ(x) ((int)x.size())
  10. #define ull unsigned long long
  11.  
  12. using namespace std;
  13.  
  14. const int N = 5e5 + ;
  15. const int inf = 0x3f3f3f3f;
  16. const LL INF = 0x3f3f3f3f3f3f3f3f;
  17. const int mod = 1e9 + ;
  18. const double eps = 1e-;
  19. const double PI = acos(-);
  20.  
  21. int n, m, q, a[N], b[N], w[N], va[N], vb[N], e[N];
  22. vector<int> vc[N];
  23.  
  24. int fa[N];
  25. int getRoot(int x) {
  26. return fa[x] == x ? x : fa[x] = getRoot(fa[x]);
  27. }
  28.  
  29. bool cmp(const int& a, const int& b) {
  30. return w[a] < w[b];
  31. }
  32.  
  33. int main() {
  34. scanf("%d%d", &n, &m);
  35. for(int i = ; i <= n; i++) fa[i] = i;
  36. for(int i = ; i <= m; i++) {
  37. scanf("%d%d%d", &a[i], &b[i], &w[i]);
  38. vc[w[i]].push_back(i);
  39. }
  40. for(int i = ; i <= ; i++) {
  41. if(!SZ(vc[i])) continue;
  42. for(auto& x : vc[i]) {
  43. va[x] = getRoot(a[x]);
  44. vb[x] = getRoot(b[x]);
  45. }
  46. for(auto& x : vc[i]) {
  47. fa[getRoot(b[x])] = getRoot(a[x]);
  48. }
  49. }
  50. scanf("%d", &q);
  51. while(q--) {
  52. bool flag = true;
  53. int num; scanf("%d", &num);
  54. for(int i = ; i <= num; i++) scanf("%d", &e[i]);
  55. for(int i = ; i <= num; i++) {
  56. if(va[e[i]] == vb[e[i]]) {
  57. flag = false;
  58. break;
  59. }
  60. }
  61. if(!flag) {
  62. puts("NO");
  63. continue;
  64. }
  65. sort(e + , e + + num, cmp);
  66. for(int L = , R = ; L <= num && flag; L = R) {
  67. while(R <= num && w[e[R]] == w[e[L]]) R++;
  68. for(int i = L; i < R; i++) {
  69. int x = va[e[i]], y = vb[e[i]];
  70. fa[x] = x, fa[y] = y;
  71. }
  72. for(int i = L; i < R; i++) {
  73. int x = va[e[i]], y = vb[e[i]];
  74. int u = getRoot(x), v = getRoot(y);
  75. if(u == v) {
  76. flag = false;
  77. break;
  78. }
  79. fa[v] = u;
  80. }
  81. }
  82. if(flag) puts("YES");
  83. else puts("NO");
  84. }
  85. return ;
  86. }
  87.  
  88. /*
  89. */

Codeforces 891C Envy的更多相关文章

  1. Codeforces 891C Envy(MST + 并查集的撤销)

    题目链接  Envy 题意  给出一个连通的无向图和若干询问.每个询问为一个边集.求是否存在某一棵原图的最小生成树包含了这个边集. 考虑$kruskal$的整个过程, 当前面$k$条边已经完成操作的时 ...

  2. CodeForces - 891C: Envy(可撤销的并查集&最小生成树)

    For a connected undirected weighted graph G, MST (minimum spanning tree) is a subgraph of G that con ...

  3. Codeforces 892E Envy

    问题描述 小Q正在玩一个叠塔的游戏,游戏的目标是叠出尽可能高的塔.在游戏中,一共有n张矩形卡片,其中第i张卡片的 长度为a_i,宽度为b_i.小Q需要把所有卡片按一定顺序叠成一座塔,要求对于任意一个矩 ...

  4. Codeforces 891 C Envy

    题目大意 给定一个 $n$ 个点 $m$ 条边的连通的无向图,每条边有一个权值,可能有重边.给出 $q$ 组询问,一组询问给出 $k$ 条边,问是否存在一棵最小生成树包含这 $k$ 条边. 思路 这道 ...

  5. Codeforces Round #446 (Div. 2)

    Codeforces Round #446 (Div. 2) 总体:rating涨了好多,虽然有部分是靠和一些大佬(例如redbag和ShichengXiao)交流的--希望下次能自己做出来2333 ...

  6. 【CF891C】Envy(最小生成树)

    [CF891C]Envy(最小生成树) 题面 Codeforces 洛谷 题解 考虑\(MST\)的构建过程,对于所有权值相同的边一起考虑. 显然最终他们连出来的结果是固定的. 把连边改为把联通块联通 ...

  7. Codeforces Round #397 by Kaspersky Lab and Barcelona Bootcamp (Div. 1 + Div. 2 combined) F. Souvenirs 线段树套set

    F. Souvenirs 题目连接: http://codeforces.com/contest/765/problem/F Description Artsem is on vacation and ...

  8. 代码的坏味道(18)——依恋情结(Feature Envy)

    坏味道--依恋情结(Feature Envy) 特征 一个函数访问其它对象的数据比访问自己的数据更多. 问题原因 这种气味可能发生在字段移动到数据类之后.如果是这种情况,你可能想将数据类的操作移动到这 ...

  9. python爬虫学习(5) —— 扒一下codeforces题面

    上一次我们拿学校的URP做了个小小的demo.... 其实我们还可以把每个学生的证件照爬下来做成一个证件照校花校草评比 另外也可以写一个物理实验自动选课... 但是出于多种原因,,还是绕开这些敏感话题 ...

随机推荐

  1. Objects源码解析

    Objects类解析 ​ JDK7新增Objects类介绍(以下程序以1.8来说明) 简介: ​ JDK7里面新增的Objects类,本人学习HashMap源码偶遇此类,所以研究一下,本类将对象常用的 ...

  2. linq to xml 简单的增、删、改、查、保存xml文件操作

    using System; using System.Collections; using System.Configuration; using System.Data; using System. ...

  3. Java EE之Struts2路径访问小结

    一.项目WEB视图结构 注释:struts.xml:最普通配置,任何无特殊配置 二.访问页面 1.访问root.jsp //方式1: http://localhost/demo/root.jsp // ...

  4. Java EE之Struts2-2.5配置

    开学以来,已经三周了.Java EE却不太走心,于是,这几日空杯心态,重新学习.复习了Java SE和Java Web开发技术,然后入手Struts2.为了使用最新版本的Structs2,我去官网下载 ...

  5. 第16月第6天 vs2005 lseek directdraw

    1. //_lseek(file_handle, -(int)pbitmap->bitmapinfoheader.biSizeImage, SEEK_END); SetFilePointer(( ...

  6. 3D点云数据分析:pointNet++论文分析及阅读笔记

    PointNet的缺点: PointNet不捕获由度量空间点引起的局部结构,限制了它识别细粒度图案和泛化到复杂场景的能力. 利用度量空间距离,我们的网络能够通过增加上下文尺度来学习局部特征. 点集通常 ...

  7. [Shell]获取IP地址

    ifconfig eth0 | grep "inet addr:" | awk '{print $2}' | cut -c 6- ifconfig eth1 | grep &quo ...

  8. Linux中THIS_MODULE宏定义详解

    一直都在耿耿于怀,这个THIS_MODULE到底是个什么玩意,linux内核中无处不在的东西.今天上网搜了一下,算是基本明白了.网上牛人写的已经比较详细,另外目前暂时没有时间往更深层次分析,所以直接贴 ...

  9. as 插件GsonFormat用法(json字符串快速生成javabean)

    GsonFormat 主要用于使用Gson库将JSONObject格式的String 解析成实体,该插件可以加快开发进度,使用非常方便,效率高. 插件地址:https://plugins.jetbra ...

  10. Lodash JavaScript 实用工具库

    地址:https://www.lodashjs.com/ Lodash 是一个一致性.模块化.高性能的 JavaScript 实用工具库.