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 ...
随机推荐
- (十)web服务与javaweb结合(1)
一.解决方法 A . 编写一个监听器,在监听器中发布服务 二.案例一 方法A:编写一个监听器,在监听器中发布服务 1. 编写服务接口 package com.shyroke.service; impo ...
- linux之find的使用
基本语法 find [查找目录] [选项] [查找规则] [查找完后的操作] 即:find pathname -option -condition [-print -exec -ok …] 选项参数 ...
- Asp.Net Mvc项目添加WebApi
1.添加一个WebApi 空项目 2.删除WebApi项目下的 Global.asax 文件,因为我们要把WebApi项目整合到Mvc项目中去,全局只需要一个Global 3.修改 WebApi 项目 ...
- 通过gpio控制一个进程开启或关闭
目标: 板子上有个进程需要通过读取gpio的值, 当gpio值为1 时, 开启指定的进程,当gpio为0时, 杀掉这个指定的进程. #include <stdio.h> int main( ...
- JFinal(2)JFinal 学习资料
JFinal 学习资料 :http://pan.baidu.com/s/1hsOcQ0G 密码:7lq3 , jfinal社区收费会员内部部分资料,博主网络搜集而来
- java 框架-分布式服务框架2Dubbo
https://blog.csdn.net/houshaolin/article/details/76408399 1. Dubbo是什么? Dubbo是一个分布式服务框架,致力于提供高性能和透明化的 ...
- 基于【 Docker】四 || Docker常用镜像安装
一.nginx安装 1.拉取镜像:docker pull nginx 2.启动容器:docker run -d -p 80:80 nginx 3.查看nginx:ps aux | grep 'ngin ...
- es6中Array.from()
Array.from()方法就是将一个类数组对象或者可遍历对象转换成一个真正的数组. 那么什么是类数组对象呢?所谓类数组对象,最基本的要求就是具有length属性的对象. 1.将类数组对象转换为真正数 ...
- Image Processing and Analysis_15_Image Registration:Image matching as a diffusion process: An analogy with Maxwell's demons——1998
此主要讨论图像处理与分析.虽然计算机视觉部分的有些内容比如特 征提取等也可以归结到图像分析中来,但鉴于它们与计算机视觉的紧密联系,以 及它们的出处,没有把它们纳入到图像处理与分析中来.同样,这里面也有 ...
- DAY2新手选品原则及供应商选择
一.新手选品原则(主要是为了起量) 1.净利润率高(容易起量) 2.发货方便,售后方便(发货,打包方便,不易破损,退货率低) 3.具有细分市场优势(衣服->古代衣服,论文排版) 4.市场规模够大 ...