【题解】CF891CEnvy
【题解】 CF891C Envy
很好玩的一道题。尽管不难,但是调了很久QAQ
考虑克鲁斯卡尔最小生成树的算法,可以发现这些最小树生成的性质:
当生成树所有边的权值都\(\le\)某个$ w$的时刻,点的连通性是确定的。
只要是同一个图的最小生成树,记\(f(w)\)是权值为\(w\)的边在最小树中生成次数,\(f(w)\)是确定的。
实际上这就是一个拟阵的基本性质
但是做这道题我个人认为只需要考虑第一个性质就好了。
分析克鲁斯卡尔究竟在干嘛,是不是它就是在"不联通的就连上边,联通的就算了",这样的最终结果都是两个点成功联通了。
再考虑克鲁斯卡尔的顺序,发现点联通的顺序是不变的,因为是按照\(e[t].w\)升序的。
再仔细分析一下克鲁斯卡尔到底在干嘛,是不是对于当前选中边的两个端点,假若联通就丢弃这条边,不联通就选取这条边。
考虑克鲁斯卡尔的性质,我们就记录一下对于一条边,当所有\(\le w\)的边加入后,两端点的联通情况。
查询是问给定一个边集,是否可以得到一个包括所有这些边的MST
那么我们把边集按照\(w\)分类,每个\(w\)单独判断是否合法就好了。
怎么判断是否合法呢?不选取的条件就是两个端点不能联通,我们在主函数里预处理一下所有\(w\)的联通情况,(们只需记录端点在不在一起),那么查询这些边是否构成环就好了。
怎么判环?并查集。但是并查集初始化\(O(n)\),会\(O(mn)TLE\)。不会持久化结构,但是有个\(tirck\) ,就是我们只初始化我们要用的点,这样的正确性也很显然。
#include<bits/stdc++.h>
using namespace std;typedef long long ll;
#define DRP(t,a,b) for(register int t=(a),edd=(b);t>=edd;--t)
#define RP(t,a,b) for(register int t=(a),edd=(b);t<=edd;++t)
#define ERP(t,a) for(register int& t=head[a];t;t=e[t].nx)
#define midd register int mid=(l+r)>>1
#define TMP template < class ccf >
#define lef l,mid,pos<<1
#define rgt mid+1,r,pos<<1|1
#define pushup(pos) (seg[pos]=seg[pos<<1]+seg[pos<<1|1])
TMP inline ccf qr(ccf b){
register char c=getchar();register int q=1;register ccf x=0;
while(c<48||c>57)q=c==45?-1:q,c=getchar();
while(c>=48&&c<=57)x=x*10+c-48,c=getchar();
return q==-1?-x:x;}
TMP inline ccf Max(ccf a,ccf b){return a<b?b:a;}
TMP inline ccf Min(ccf a,ccf b){return a<b?a:b;}
TMP inline ccf Max(ccf a,ccf b,ccf c){return Max(a,Max(b,c));}
TMP inline ccf Min(ccf a,ccf b,ccf c){return Min(a,Min(b,c));}
TMP inline ccf Abs(ccf a){return a<0?-a:a;}
TMP inline ccf READ(ccf* _arr,int _n){RP(t,1,_n)_arr[t]=qr((ccf)1);}
//----------------------template&IO---------------------------
const int maxn=1e5+15;
struct E{
int to,nx,id;
}e[maxn<<2];
int head[maxn];
int dfn[maxn<<1];
int ind[maxn];
int oud[maxn];
bool usd[maxn<<1];
int n,m;
int cnt;
int top;
inline void add(int fr,int to,int id,bool f){
e[++cnt]=(E){to,head[fr],id};head[fr]=cnt;
if(f) add(to,fr,-id,0);
}
void dfs(int now){
ERP(t,now){
register int qaq=t;
if(usd[abs(e[qaq].id)]) continue;
usd[abs(e[qaq].id)]=1;
dfs(e[qaq].to);
dfn[++top]=e[qaq].id;
}
}
int main(){
#ifndef ONLINE_JUDGE
freopen("in.in","r",stdin);
freopen("out.out","w",stdout);
#endif
register int t1=qr(1)&1;
n=qr(1);m=qr(1);
for(register int t=1,r1,r2;t<=m;++t){
r1=qr(1);r2=qr(1);
add(r1,r2,t,t1);
++oud[r1];++ind[r2];
}
if(t1) {RP(t,1,n) if((ind[t]+oud[t])&1) return puts("NO"),0;}
else {RP(t,1,n) if(ind[t]^oud[t]) return puts("NO"),0; }
RP(t,1,n) if(head[t]) {dfs(t);if(top^m) return puts("NO"),0;break;}
puts("YES");
DRP(t,m,1) printf("%d ",dfn[t]);
putchar('\n');
return 0;
}
【题解】CF891CEnvy的更多相关文章
- 2016 华南师大ACM校赛 SCNUCPC 非官方题解
我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...
- noip2016十连测题解
以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...
- BZOJ-2561-最小生成树 题解(最小割)
2561: 最小生成树(题解) Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1628 Solved: 786 传送门:http://www.lyd ...
- Codeforces Round #353 (Div. 2) ABCDE 题解 python
Problems # Name A Infinite Sequence standard input/output 1 s, 256 MB x3509 B Restoring P ...
- 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解
题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...
- 2016ACM青岛区域赛题解
A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Jav ...
- poj1399 hoj1037 Direct Visibility 题解 (宽搜)
http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...
- 网络流n题 题解
学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...
- CF100965C题解..
求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...
随机推荐
- 网站安全测试工具GoLismero
网站安全测试工具GoLismero GoLismero是一款开源的安全测试框架.目前,它的测试目标主要为网站.该框架采用插件模式,实现用户所需要的功能.GoLismero默认自带了导入.侦测.扫描.攻 ...
- Spring事务管理——事务的传播行为
1.简介 当事务方法被另一个事务方法调用时,必须指定事务应该如何传播.例如:方法可能继续在现有事务中运行,也可能开启一个新事务,并在自己的事务中运行. 事务的传播行为可以由传播属性指定.Spring定 ...
- Android Touch事件传递机制详解 下
尊重原创:http://blog.csdn.net/yuanzeyao/article/details/38025165 资源下载:http://download.csdn.net/detail/yu ...
- xamarin.ios 本地通知推送
由于ios10版本以后UILocalNotification被标为弃用了,所以要添加新的本地通知推送功能,下面提供一些代码参考. 一.先在AppDelegate.cs上注册本地通知推送功能. publ ...
- metasploit study
load db_trackerdb_nmap -T Aggressive -sV -n -O -v 192.168.0.107 绑定shelluse exploit/windows/smb/ms08_ ...
- Mac. 文件夹赋予权限
1. click on your background to go to finder click on go and go to folder /usr right click on local a ...
- Windows脚本\批处理命令学习笔记
1.为新建变量赋值: set 变量=值 2.输出变量的值 echo %变量% 3.关闭批处理中命令行的显示(默认是显示命令行的) 在文件開始处增加:echo off 若需又一次显示:echo on 若 ...
- 用户空间和内核空间通讯之【Netlink 上】
原文地址:用户空间和内核空间通讯之[Netlink 上] 作者:wjlkoorey258 引言 Alan Cox在内核1.3版本的开发阶段最先引入了Netlink,刚开始时Netlink是以字符驱动接 ...
- JAVA Eclipse 创建android xml看不到预览怎么办
电机安卓图标,设置为更低的API版本即可
- UNP学习笔记(第五章 TCP客户/服务程序实例)
我们将在本章使用前一章中介绍的基本函数编写一个完整的TCP客户/服务器程序实例 这个简单得例子是执行如下步骤的一个回射服务器: TCP回射服务器程序 #include "unp.h" ...