「LibreOJ β Round #3」绯色 IOI(抵达)


【题解】
我们可以发现叶子节点的关联点一定是它的父亲节点,那么我们dfs一遍就可以求出所有节点的关联点,或者判断出无解。
对于每个点i,它的关联点u的危险度肯定比它连接的其他点vi的危险度小,我们从u向vi连边。
连边之后我们跑拓扑排序,并且用堆维护当前入度为0的点中编号最小的,以此来让字典序最小。
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<queue>
#define LL long long
#define rg register
#define N 1000010
using namespace std;
int n,tot,cnt,last[N],last2[N],link[N],in[N],q[N],ans[N];
bool vis[N],sol=;
struct edge{int to,pre;}e[N<<],e2[N<<];
priority_queue<int,vector<int>,greater<int> >f;
char buf[],*ptr=buf-;
inline int read(){
int f=,k=; char c=*++ptr;
while(c<'' || c>'') c=='-'&&(f=-), c=*++ptr;
while(c<='' && c>='') k=k*+c-'', c=*++ptr;
return k*f;
}
void dfs(int x,int fa){
if(!sol) return;
bool ok=;
for(rg int i=last[x],to;i;i=e[i].pre)if((to=e[i].to)!=fa){
dfs(to,x); if(!vis[to]) link[x]=to,vis[to]=,ok=;
}
if(!ok){
if(vis[fa]) sol=;
else link[x]=fa,vis[fa]=;
}
}
void dfs2(int x,int fa){
int u=link[x];
for(rg int i=last[x],to;i;i=e[i].pre)if((to=e[i].to)!=link[x]){
in[to]++;
e2[++tot]=(edge){to,last2[u]}; last2[u]=tot;
// printf("%d-->%d\n",u,to);
}
for(rg int i=last[x],to;i;i=e[i].pre)if((to=e[i].to)!=fa) dfs2(to,x);
}
int main(){
// freopen("minecraft.in","r",stdin);
// freopen("minecraft.out","w",stdout);
fread(buf, , sizeof(buf), stdin);
n=read();
for(rg int i=;i<n;i++){
int u=read(),v=read();
e[++tot]=(edge){v,last[u]}; last[u]=tot;
e[++tot]=(edge){u,last[v]}; last[v]=tot;
}
vis[]=;
dfs(,);
if(!sol){puts("-1"); return ;}
// for(rg int i=1;i<=n;i++) printf("%d ",link[i]); puts("link");
tot=;
dfs2(,);
// for(rg int i=1;i<=n;i++) printf("%d ",in[i]); puts("in");
for(rg int i=;i<=n;i++)if(!in[i]){
f.push(i);
}
while(f.size()){
int now=f.top(); f.pop();
ans[++cnt]=now;
for(rg int i=last2[now],to;i;i=e2[i].pre){
in[to=e2[i].to]--;
if(!in[to]) f.push(to);
}
}
for(rg int i=;i<=n;i++) printf("%d ",ans[i]);
return ;
}
做法二:
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<queue>
#define LL long long
#define rg register
#define N 500010
using namespace std;
int n,m,tot,ans[N],last[N],deg[N];
bool vis[N],cut[N<<];
struct edge{
int to,pre;
}e[N<<];
priority_queue<int,vector<int>,greater<int> >q;
inline int read(){
int k=,f=; char c=getchar();
while(c<''||c>'')c=='-'&&(f=-),c=getchar();
while(''<=c&&c<='')k=k*+c-'',c=getchar();
return k*f;
}
int main(){
n=read(); tot=;
if(n==) return puts("-1"),;
for(rg int i=;i<n;i++){
int u=read(),v=read();
e[++tot]=(edge){u,last[v]}; last[v]=tot;
e[++tot]=(edge){v,last[u]}; last[u]=tot;
deg[u]++; deg[v]++;
}
for(rg int i=;i<=n;i++)if(deg[i]<=) q.push(i),vis[i]=;
for(rg int t=,now;t<=n;t++){
if(!q.size()){puts("-1"); return ;}
ans[t]=now=q.top(); q.pop();
for(rg int i=last[now],to;i;i=e[i].pre)if(!cut[i]){
to=e[i].to;
for(rg int j=last[to],to2;j;j=e[j].pre){
deg[to2=e[j].to]--;
if(!vis[to2]&°[to2]<=) q.push(to2),vis[to2]=;
cut[j^]=;
}
}
}
for(rg int i=;i<=n;i++) printf("%d ",ans[i]);
return ;
}
「LibreOJ β Round #3」绯色 IOI(抵达)的更多相关文章
- [LOJ#522]「LibreOJ β Round #3」绯色 IOI(危机)
[LOJ#522]「LibreOJ β Round #3」绯色 IOI(危机) 试题描述 IOI 的比赛开始了.Jsp 和 Rlc 坐在一个角落,这时他们听到了一个异样的声音 …… 接着他们发现自己收 ...
- loj #547. 「LibreOJ β Round #7」匹配字符串
#547. 「LibreOJ β Round #7」匹配字符串 题目描述 对于一个 01 串(即由字符 0 和 1 组成的字符串)sss,我们称 sss 合法,当且仅当串 sss 的任意一个长度为 ...
- [LOJ#531]「LibreOJ β Round #5」游戏
[LOJ#531]「LibreOJ β Round #5」游戏 试题描述 LCR 三分钟就解决了问题,她自信地输入了结果-- > -- 正在检查程序 -- > -- 检查通过,正在评估智商 ...
- [LOJ#530]「LibreOJ β Round #5」最小倍数
[LOJ#530]「LibreOJ β Round #5」最小倍数 试题描述 第二天,LCR 终于启动了备份存储器,准备上传数据时,却没有找到熟悉的文件资源,取而代之的是而屏幕上显示的一段话: 您的文 ...
- [LOJ#516]「LibreOJ β Round #2」DP 一般看规律
[LOJ#516]「LibreOJ β Round #2」DP 一般看规律 试题描述 给定一个长度为 \(n\) 的序列 \(a\),一共有 \(m\) 个操作. 每次操作的内容为:给定 \(x,y\ ...
- [LOJ#515]「LibreOJ β Round #2」贪心只能过样例
[LOJ#515]「LibreOJ β Round #2」贪心只能过样例 试题描述 一共有 \(n\) 个数,第 \(i\) 个数 \(x_i\) 可以取 \([a_i , b_i]\) 中任意值. ...
- [LOJ#525]「LibreOJ β Round #4」多项式
[LOJ#525]「LibreOJ β Round #4」多项式 试题描述 给定一个正整数 k,你需要寻找一个系数均为 0 到 k−1 之间的非零多项式 f(x),满足对于任意整数 x 均有 f(x) ...
- [LOJ#526]「LibreOJ β Round #4」子集
[LOJ#526]「LibreOJ β Round #4」子集 试题描述 qmqmqm有一个长为 n 的数列 a1,a2,……,an,你需要选择集合{1,2,……,n}的一个子集,使得这个子集中任意两 ...
- LibreOJ #517. 「LibreOJ β Round #2」计算几何瞎暴力
二次联通门 : LibreOJ #517. 「LibreOJ β Round #2」计算几何瞎暴力 /* LibreOJ #517. 「LibreOJ β Round #2」计算几何瞎暴力 叫做计算几 ...
随机推荐
- “XXX.Index”不扩展类“System.Web.UI.Page”,因此此处不允许的问题
“XXX.Index”不扩展类“System.Web.UI.Page”,因此此处不允许的问题 原因:设计页面继承的路径和后台.cs页面类的路径不一致造成的 看下图 这个是设计页面的样式 这个是后台cs ...
- Codeforces Round #323 (Div. 2)
被进爷坑了,第二天的比赛改到了12点 水 A - Asphalting Roads /************************************************ * Author ...
- Spring-bean(二)
命名空间 自动装配 bean之间的关系:继承:依赖 使用外部属性文件 SpEL bean的生命周期 bean的后置处理器 (一)util命名空间 当用list,set等集合时,不能将集合作为独立的be ...
- xcopy递归拷贝
递归拷贝 ::xcopy SOURCE_DIR DES_DIR\ /s SOURCE_DIR后面不需要加反斜杠
- JDBC的fetchsize和maxrows
在我们的项目开发中,可能有把SQL查询的结果保存到CSV然后提供下载的功能.当查询的结果集相当大的时候,很容易报内存不足错误(outofmemory).那该怎么解决这种情况的内存不足错误呢? 其实在J ...
- Spotlight安装
刚才技术群的一个朋友在安装Spotligh出现了一些问题,所以本人临时写个简单的教程 1.下载安装包(安装包地址:https://pan.baidu.com/s/1c2tmqyc),解压,然后傻瓜式安 ...
- codevs 1422 河城荷取
时间限制: 1 s 空间限制: 128000 KB 题目等级 : 大师 Master 题目描述 Description 在幻想乡,河城荷取是擅长高科技工业的河童.荷取的得意之作除了光学迷彩外,还有 ...
- SPICE-HTML5 鼠标指针BUG修复
研究SPICE,找到了他们官方指定的HTML5客户端.下载下来用一下,发现跟网页VNC的水平差不多了.http://www.spice-space.org/page/Html5 服务端直接用QEMU起 ...
- Android系统级技巧合集
Android系统级技巧合集(随时更新) #转载请注明来源# 1.高通骁龙系列查看CPU体质等级 CPU体质,即为CPU在工作频率下的电压.同一批次的CPU体质各有不同,体质越高,代表该颗CPU可在更 ...
- 浅析HashSet add() 方法存储自定义类型对象的过程
一.自定义一个Student类 package date0504; public class Student { private String id; Student(String id){ this ...