CF1053E Euler tour
题意
给出一个某些位置不全的欧拉序,求出一个符合条件的,或输出不行
传送门
\(n \le 5*10^5\)
思路
终于不是一道神仙\(dp\)
变成了一道神仙构造
以下简称两相同数围成的是一个区间,基本性质:
- 两个相同数之间的长度为奇数
- 头尾一定相同
- 区间要么完全包含要么不相交
- 某段区间内已确定的落单的数一定小于区间\(0\)的个数\(+1\),因为一个落单的数除了叶子总得再配一个
- 对任意一棵大小为\(x\)的子树,序列长度为\(2x-1\)
首先区间不相交就让我们可以分治搞下去,先递归到最小的区间处理,然后处理完此区间对答案就没有影响了,可以直接删掉(浓缩成一个根节点代替整个子树),具体就是维护一下前驱和后继循环时一段一段跳就好了。
接着要考虑最小的区间怎么办了。考虑一下填完后确定的数一定是\(\lfloor \frac{区间长度+1}2 \rfloor\),那么首先从前往后在多出来的空格填未出现过的数字。
接着就开始了,形如\(120\)或\(021\)的,只要填成\(121\),也就是我们要不停的找如\(xy0\)或\(0xy\)的某三个数,并且填完后把它们当做只有\(2\)也就是父亲节点就好了。
如果还有是没填的怎么办呢?发现当前区间的父亲可以用来分割两个区间。
例如填完后变成了\(1[20304]1\)括号表示当前区间,无法用前面的方法再来填,那就可以用\(1\)来填补剩下的空格变为\(1213141\)
#include <bits/stdc++.h>
using std::deque;
const int N=1000100;
int suf[N],pre[N],Next[N],last[N],c[N],a[N],n,m,now;
struct note{
int x,p;
};
deque <note> q;
void endd(){
puts("no");
exit(0);
}
void del(int x,int y){
suf[x]=suf[y];
pre[suf[y]]=x;
}
int get(){
while (c[now]) now++;
if (now>n) endd();
c[now]=1;
return now;
}
void solve(int l,int r){
if (r<l) return;
if ((r-l)&1) endd();
for (int i=l;i<=r;i=suf[i]){
if (!a[i]) continue;
while (Next[i]){
int to=Next[i];
if (to>r) endd();
solve(suf[i],pre[to]);
del(i,to);
Next[i]=Next[to];
}
}
int sum=0,sum0=0;
for (int i=l;i<=r;i=suf[i]){
sum+=(a[i]>0);
sum0+=(!a[i]);
}
if (sum0<sum-1) endd();
for (int i=l;i<=r && sum0>sum;i=suf[i])
if (!a[i]) a[i]=get(),sum0--,sum++;
int rt=a[pre[l]];
for (int i=l;suf[i]<=r;i=suf[i]){
while (i>l && suf[i]<=r && a[i] && a[suf[i]] && (!a[pre[i]])){
a[pre[i]]=a[suf[i]];
del(pre[i],suf[i]);
i=pre[pre[i]];
}
while (i>=l && suf[suf[i]]<=r && a[i] && a[suf[i]] && (!a[suf[suf[i]]])){
a[suf[suf[i]]]=a[i];
del(i,suf[suf[i]]);
i=pre[i];
}
}
for (int i=l;i<=r;i=suf[i])
if (!a[i]) a[i]=rt;
}
int main(){
scanf("%d",&n);
m=2*n-1;
for (int i=1;i<=m;i++) scanf("%d",&a[i]),c[a[i]]++;
if (a[1]!=a[2*n-1] && a[1] && a[2*n-1]) endd();
a[1]=a[m]=(a[1]|a[m]);
for (int i=m;i>=1;i--)
Next[i]=last[a[i]],last[a[i]]=i;
now=1;
suf[0]=1;
for (int i=1;i<=m;i++) pre[i]=i-1,suf[i]=i+1;
solve(1,m);
puts("yes");
for (int i=1;i<=m;i++) printf("%d ",a[i]);
}
后记
神仙啊,其实我还是不怎么懂
CF1053E Euler tour的更多相关文章
- CF1053E Euler tour 构造
正解:构造 解题报告: 传送门! 这种题目一般都是首先考虑合法性 这题也不例外,思考怎么样是合法的呢? 有四点: 1)a[1]=a[2n-1],显然不说 2)若a[i]=a[j],则(j-i)& ...
- 【CF1053E】Euler tour
[CF1053E]Euler tour 题面 CF 洛谷 大概意思是你有一棵树,然而你并不知道这棵树是啥.给你一个确定了一些位置的欧拉序(就是\(ST\)表求\(LCA\)的那个序列),问你是否存在一 ...
- Euler Tour Tree与dynamic connectivity
Euler Tour Tree最大的优点就是可以方便的维护子树信息,这点LCT是做不到的.为什么要维护子树信息呢..?我们可以用来做fully dynamic connectivity(online) ...
- 2018.09.25 codeforces1053E. Euler tour(并查集+st表+模拟)
传送门 毒瘤细节题. 首先考虑不合法的情况. 先把相同的值配对,这样就构成了一些区间. 那么如果这些区间有相交的话,就不合法了. 如何判断?DZYO安利了一波st表,我觉得很不错. 接着考虑两个相同的 ...
- poj1637--Sightseeing tour(最大流)
最大流求混合图是否存在欧拉回路. 以下内容摘自http://www.cnblogs.com/Missa/archive/2012/12/05/2803107.html 讲的很清楚. 混合图的欧拉回路问 ...
- uva10735 Euler Circuit
题外话:很多混合图问题可以转化为有向图问题(将无向边拆为两条有向边) 本题不行,因为只能经过一次 这种问题能想到网络流.. 复习欧拉回路:入度==出度 和uva1380有点相似,要先给无向边定向.原图 ...
- Range Minimum Query and Lowest Common Ancestor
作者:danielp 出处:http://community.topcoder.com/tc?module=Static&d1=tutorials&d2=lowestCommonAnc ...
- GDKOI2015 Day1
P1 题目描述: 判断一个环形字符串(或者减去一个字符之后)是否是回文串 solution: 1.hash 将字符串的前缀进行hash,然后将字符串翻转,再做一次hash,然后枚举对称轴,判断两边的h ...
- 混合欧拉回路的判断(Dinic)
POJ1637 Sightseeing tour Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 7483 Accepte ...
随机推荐
- (一)SpringBoot之简介和安装插件以及HelloWorld第一个程序
一.简介 Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Spring应用的初始搭建以及开发过程.该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的 ...
- Rider开发开发.NET Framework 4.5项目遇到的一些问题
使用rdier自带resharper功能,蛮爽的但是编译旧的项目时一直报错:Invalid option 'portable' for /debug; must be full or pdbonly' ...
- Xamarin(Android)制作启动画面
1.将启动图片保存到Drawable文件夹下 2.在Drawable文件夹下创建splashscreen.xml <?xml version="1.0" encoding=& ...
- JQuery攻略读书笔记---第2章 数组
2 数组2.8 创建对象数组循环数组2.9 数组排序 2 数组 2.8 创建对象数组 //数组化对象 var student =[ { "role":101, "na ...
- Go part 5 结构体,方法与接收器
结构体 结构体定义 结构体的定义只是一种内存布局的描述(相当于是一个模板),只有当结构体实例化时,才会真正分配内存空间 结构体是一种复合的基本类型,通过关键字 type 定义为 自定义 类型后,使结构 ...
- A*算法与8数字谜题(参见《算法》P226习题2.5.32)
A*算法的目的是找到一条从起始状态到最终状态的最短路径. 在A*算法中,需要在每个点计算启发函数:f(S) = g(S) + h(S),其中g(S)是从起点到S点的距离,h(S)是对从S点到终点的最短 ...
- ajax简单页面
简单的注册页面运用ajax 主页面 <head><meta http-equiv="Content-Type" content="text/html; ...
- menustrip选项怎么设置竖向分割线
效果图: 解决方案: 选中一个项--[右键]--[插入]--[separator]
- impala 中SQL的优化方法
1.取流水表的数据时,如果是使用全部分区数据,不能从SA层数据取数,需要改从SH层取数,因为SH层为parquet存储,查询性能较好. 2.对于脚本中使用的临时表,如果存在以下情况需要进行统计表信息 ...
- linux服务器忘记密码操作
当重启镜像时候 看到这个界面的时候 按1 按1之后进入如下界面 红色区域有解释 按e是编译模式,我们按e OK 这里我们选择第二行按b 进入开发者模式,然后等待启动 然后更改密码