【题解】 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的更多相关文章

  1. 2016 华南师大ACM校赛 SCNUCPC 非官方题解

    我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...

  2. noip2016十连测题解

    以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...

  3. BZOJ-2561-最小生成树 题解(最小割)

    2561: 最小生成树(题解) Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1628  Solved: 786 传送门:http://www.lyd ...

  4. Codeforces Round #353 (Div. 2) ABCDE 题解 python

    Problems     # Name     A Infinite Sequence standard input/output 1 s, 256 MB    x3509 B Restoring P ...

  5. 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解

    题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...

  6. 2016ACM青岛区域赛题解

    A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Jav ...

  7. poj1399 hoj1037 Direct Visibility 题解 (宽搜)

    http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...

  8. 网络流n题 题解

    学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...

  9. CF100965C题解..

    求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...

随机推荐

  1. (入门SpringBoot)SpringBoot后台验证(八)

    后台验证的作用主要是防止postman...等等工具的恶意提交,前后台都判断数据,双保险. .可以在SpringBoot传参数 加上NotNull.... //分组Default,分组的好处就是可重复 ...

  2. 书写一个程序,把变量n的初始值设置为1957,然后利用除法运算和取余运算把变量n的每一位数字都抽出来并打印

    class number { void num(){ int a,b,c,d; int n=1957; a=n/1000; b=n/100%10; c=n/10%10; d=n%10; System. ...

  3. PathInterpolator

    PathInterpolator 在v4 support library:Revision 22.1.0的时候,Google在兼容库中增加了几个新的类,用于创建更加真实的动画效果. Added the ...

  4. php从数据库选取记录形成列表(首页调用)

    <ul class="e1"> <?php $querySel = "select ID,Tit,Addtime from news where DSh ...

  5. VS2010 MFC中 给菜单项添加消息响应函数

    久了没用,居然忘记了该怎样给菜单项添加响应函数了~~~~~~~~T_T 特记于此: 1. 在资源视图的Menu里找到自己要添加的菜单,然后输入菜单项. 2. 右击菜单项选属性,设置Popup为Fals ...

  6. 【温故知新】——BABYLON.js学习之路·前辈经验(一)

    前言:公司用BABYLON作为主要的前端引擎,同事们在长时间的项目实践中摸索到有关BABYLON的学习路径和问题解决方法,这里只作为温故知新. 一.快速学习BABYLON 1. 阅读Babylon[基 ...

  7. mysql root密码忘记最快方法

    在my.cnf [mysqld]栏添加 skip-grant-tables 然后重启/etc/init.d/mysqld restart mysql ##select password('新密码') ...

  8. 解释一下Windows dos中的符号

    容许我放一段Windows的批处理: sc <server> [command] [service name] <option1> <option2>... < ...

  9. 每天5道面试题(二)java基础

    说出Servlet的生命周期,并说出Servlet和CGI的差别 Servlet被server实例化后,容器执行其init方法,请求到达时执行其service方法,service方法自己主动派遣执行与 ...

  10. ZF-net

    ZF-net 摘要: 1.这篇文章的motivation 是 :CNN性能良好,可是我们不知道它为何性能良好.也不知道它怎么能够被提高? 2.本文介绍了一种新方法实现中间层和分类器的可视化 3.採用消 ...