【题解】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 & ...
随机推荐
- UVA - 1205 Color a Tree
大意就是给你一颗树,每个点有一个权值w[i],求一个排列使得 所有的父亲都在儿子前面 并且排列的权值最小. 排列的权值在这里定义为 Σ i * w[p[i]] ,其中p[i] 是排列第i个位置的元 ...
- linux基础学习7
Linux 的开机流程分析 1. 加载 BIOS 的硬件信息与进行自我测试,并依据设定取得第一个可开机的装置: 2. 读取并执行第一个开机装置内 MBR 的 boot Loader (亦即是 gr ...
- Win7如何自定义鼠标右键菜单 添加在此处打开CMD窗口
将下面文件保存为"右键添加在此处打开CMD窗口.reg"双击导入运行即可 Windows Registry Editor Version 5.00 [HKEY_CLASSES_RO ...
- nginx apache防盗链
要实现防盗链,我们就必须先理解盗链的实现原理,提到防盗链的实现原理就不得不从HTTP协议说起,在HTTP协议中,有一个表头字段叫referer,采用URL的格式来表示从哪儿链接到当前的网页或文件.换句 ...
- Action window Flags
Action window 主要字段使用 含义 target 值 作用 current 当前窗口 new 新窗口 inline 内联编辑 fullscreen 全屏 main 当前窗口的主动作 ...
- 微软Azure公有云个人用户是否能支付得起?
个人建立自己的站点是普通"白领"的愿望.由于,我们的大脑分泌的脑汁须要排泄渠道.怎么办呢? 依据微软公有云的公开报价(Pricing),租用单核CPU.0.75GB内存,20GB硬 ...
- 让div排成一行===>inline-block的兼容性
行内元素,排列在一行,但是不能设置它的width.height.margin.padding属性,即使设置了,也是不生效的. 快元素独占一行,如下的这个例子,before div.in div1.in ...
- iOS 自己定义页面的切换动画与交互动画 By Swift
在iOS7之前,开发人员为了寻求自己定义Navigation Controller的Push/Pop动画,仅仅能受限于子类化一个UINavigationController,或是用自己定义的动画去覆盖 ...
- oracle 客户端连接
客户端安装时选择管理员模式安装. 连接配置: 首先找到:\app\Administrator\product\11.2.0\client_1\network\admin 文件夹下 tnsnames. ...
- 【Web API系列教程】3.10 — 实战:处理数据(公布App到Azure App Service)
在这最后一节中.你将把应用程序公布到Azure.在Solution Explorer中,右击项目并选择Publish. 点击Publish打开Publish Web对话框. 假设你在新建项目的时候选中 ...