[CF891C] Envy - Kruskal,并查集
给出一个 n 个点 m条边的无向图,每条边有边权,共 Q次询问,每次给出 \(k\)条边,问这些边能否同时在一棵最小生成树上。
Solution
所有最小生成树中某权值的边的数量是一定的
加完小于某权值的所有边后图的连通性是一样的
对于每个询问,每种权值分开考虑
对每个权值,加完小于这条边的权值后的所有边
然后判断这个权值在缩点后图上是否成环
因此需要跑一次 Kruskal 并且记录下对于每条边,加完权值小于它的所有边后,其两个端点所在的连通块编号
这样询问时只需要拿着并查集搞就可以了
#include <bits/stdc++.h>
using namespace std;
const int N = 1000005;
struct edge {
int u,v,w,id,bu,bv;
bool operator < (const edge &b) const {
return w < b.w;
}
} e[N];
bool cmp(const edge &a, const edge &b) {
return a.id < b.id;
}
int n,m,q,t1,t2,t3,f[N];
int find(int x) { return f[x] == x ? x : f[x] = find(f[x]); }
void merge(int i,int j) {if(find(i)!=find(j)) f[find(i)]=find(j); }
int solve(vector <edge> v) {
/*cout<<"solve"<<endl;
for(int i=0;i<v.size();i++) cout<<v[i].bu<<" "<<v[i].bv<<" "<<v[i].w<<endl;
cout<<"-----"<<endl;*/
map<int,int> mp;
for(int i=0;i<v.size();i++) mp[v[i].bu]++, mp[v[i].bv]++;
int ind=0;
for(map<int,int>::iterator it=mp.begin();it!=mp.end();it++)
it->second = ++ind;
for(int i=0;i<v.size();i++) v[i].bu=mp[v[i].bu], v[i].bv=mp[v[i].bv];
for(int i=1;i<=ind;i++) f[i]=i;
int flag=1;
for(int i=0;i<v.size();i++) {
if(find(v[i].bu)==find(v[i].bv)) flag=0;
merge(v[i].bu,v[i].bv);
}
return flag;
}
int main() {
ios::sync_with_stdio(false);
scanf("%d%d",&n,&m);
for(int i=1;i<=m;i++) {
scanf("%d%d%d",&e[i].u,&e[i].v,&e[i].w);
e[i].id=i;
}
sort(e+1,e+m+1);
for(int i=1;i<=n;i++) f[i]=i;
for(int i=1;i<=m;i++) {
if(e[i].w != e[i-1].w) {
int pos=i;
while(e[pos].w == e[pos+1].w && pos<m) ++pos;
for(int j=i;j<=pos;j++) e[j].bu=find(e[j].u), e[j].bv=find(e[j].v);
}
merge(e[i].u,e[i].v);
}
scanf("%d",&q);
sort(e+1,e+m+1,cmp);
//for(int i=1;i<=m;i++) cout<<e[i].bu<<" "<<e[i].bv<<endl;
for(int i=1;i<=q;i++) {
int tot;
scanf("%d",&tot);
vector <edge> v;
for(int j=1;j<=tot;j++) {
int tmp;
scanf("%d",&tmp);
v.push_back(e[tmp]);
}
sort(v.begin(),v.end());
v.push_back((edge){0,0,0});
int flag = 1;
for(int j=0;j<tot;j++) {
int pos=j;
while(v[j].w == v[j+1].w && pos<tot-1) ++pos;
vector <edge> vv;
for(int k=j;k<=pos;k++) vv.push_back(v[k]);
flag &= solve(vv);
j=pos;
}
if(flag) puts("YES");
else puts("NO");
}
}
[CF891C] Envy - Kruskal,并查集的更多相关文章
- TOJ 2815 Connect them (kruskal+并查集)
描述 You have n computers numbered from 1 to n and you want to connect them to make a small local area ...
- Minimum Spanning Tree.prim/kruskal(并查集)
开始了最小生成树,以简单应用为例hoj1323,1232(求连通分支数,直接并查集即可) prim(n*n) 一般用于稠密图,而Kruskal(m*log(m))用于系稀疏图 #include< ...
- Connect the Campus (Uva 10397 Prim || Kruskal + 并查集)
题意:给出n个点的坐标,要把n个点连通,使得总距离最小,可是有m对点已经连接,输入m,和m组a和b,表示a和b两点已经连接. 思路:两种做法.(1)用prim算法时,输入a,b.令mp[a][b]=0 ...
- hdu 1863 畅通工程(Kruskal+并查集)
畅通工程 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submi ...
- POJ 3723 Conscription (Kruskal并查集求最小生成树)
Conscription Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 14661 Accepted: 5102 Des ...
- BZOJ3545 [ONTAK2010]Peaks kruskal 并查集 主席树 dfs序
欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ3545 题意概括 Description 在Bytemountains有N座山峰,每座山峰有他的高度 ...
- BZOJ3551 [ONTAK2010]Peaks加强版 kruskal 并查集 主席树 dfs序
欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ3551 题意概括 Description 在Bytemountains有N座山峰,每座山峰有他的高度 ...
- 习题:过路费(kruskal+并查集+LCA)
过路费 [问题描述]在某个遥远的国家里,有 n 个城市.编号为 1,2,3,…,n.这个国家的政府修 建了 m 条双向道路,每条道路连接着两个城市.政府规定从城市 S 到城市 T 需 要收取的过路费 ...
- HDU1863(Kruskal+并查集水题)
https://cn.vjudge.net/problem/HDU-1863 省政府“畅通工程”的目标是使全省任何两个村庄间都可以实现公路交通(但不一定有直接的公路相连,只要能间接通过公路可达即可). ...
随机推荐
- Flink知识散点
1.KeyBy 操作后,只有当 Key 的数量大于算子的并发实例数才能获得较好的计算性能. A.而若Key 的数量比实例数量少,就会导致部分实例收不到数据,这些实例就得不到执行,这些实例的计算能力得不 ...
- 树莓派点亮LED灯需要几行代码?3行。小孩子都能学会
目录 点亮LED灯 硬件连接 代码 闪烁的LED灯 呼吸灯 其他 点亮LED灯 硬件连接 找一个LED灯,连接如上图,注意长短引脚,经过这些年的狂轰乱炸,大家对于这个应该不漠视,毕竟Arduino都进 ...
- M5310-A 版本
模块外表 型号 BAND M5310-A MBRH0S04 +NB ...
- 清北学堂—2020.1提高储备营—Day 3(图论初步(一))
qbxt Day 3 --2020.1.19 济南 主讲:李奥 目录一览 1.图论(图.图的存储方式.最小生成树的定义) 总知识点:图论 前言:众所周知,图论是一个非常重要的部分,而这次集训也可以算从 ...
- C# Winform初体验
设计一个简单的登录窗口,要求输入用户名:小金,密码:123456时候点登录能正确转到另一个窗口. 1.建立窗体应用. 2.这里创建一个login和一个NewForm的窗体. 3.在login的窗体拖拉 ...
- SPFA的优化一览
目录 序 内容 嵬 序 spfa,是一个早已没人用的算法,就像那些麻木的人, 可谁有知道,他何时槃涅 一个已死的算法 ,重生 内容 关于\(NOI2018D1T1\)的惨案,为了以防spfa被卡. 关 ...
- Django---Django安装数据库
前面我们介绍了如何通过Django完成数据的接收和数据交互,那么我们都知道,数据一般都是通过数据库存储的,然而我们作为测试肯定和数据库也是经常打交道的,今天就简单的介绍下,如何在windows上安装数 ...
- 剑指offer-面试题29-顺时针打印矩阵-矩阵
/* 题目: 输入一个矩阵,按照从外到内顺时针的顺序依次打印每一个数字. */ /* 思路: 1.将打印矩阵看作是打印一个个从外向内的环. 2.每一个环都有一个起始节点,起始节点的坐标*2小于行数和列 ...
- js 时间格式转换
js时间格式转换 格式化时间转成时间戳 //格式化转时间戳(单位秒) function strtotime(strtime) { strtime = strtime.substring(0, 19); ...
- jsp环境搭建
jsp开发环境需要JDK与Tomcat,需先下载JDK组件与tomcat组件 JDK地址:https://www.oracle.com/technetwork/java/javase/download ...