bzoj3506

此题是一道比较简单的spaly题目。

用splay维护序列,将每个点排到对应的位置之后删除,这样比较容易区间翻转。

我的指针写法在洛谷上AC了,但在bzoj上RE。

#include <cstdio>
#include <algorithm>
using namespace std;
inline int gi() {
register int a; register char c;
while(c=getchar(),c<'0');a=c-'0';
while(c=getchar(),'-'<c)a=(a<<3)+(a<<1)+c-'0';
return a;
}
#define N 100010
struct node {
int s; bool ly;
node*fa,*ch[2];
}MSET[N],*cnode=MSET,*mp[N],*nil,*rt;
pair<int,int>pr[N]; int rk[N];
inline void maintain(node*u) {u->s=1+u->ch[0]->s+u->ch[1]->s;}
inline void reverse(node*u) {u->ly^=1,swap(u->ch[0],u->ch[1]);}
inline void pushdown(node*u) {
if(!u->ly)return;
u->ly=false;
if(u->ch[0]!=nil)reverse(u->ch[0]);
if(u->ch[1]!=nil)reverse(u->ch[1]);
}
inline void rot(node*u) {
node*f=u->fa,*ff=f->fa;
int d=u==f->ch[1];
pushdown(f),pushdown(u);
if((f->ch[d]=u->ch[d^1])!=nil)f->ch[d]->fa=f;
if((u->fa=ff)!=nil)ff->ch[f==ff->ch[1]]=u;
u->ch[d^1]=f,f->fa=u;
maintain(f),maintain(u);
}
inline void splay(node*u,node*target) {
for(node*f;u->fa!=target;rot(u))
if((f=u->fa)->fa!=target)((u==f->ch[1])^(f==f->fa->ch[1]))?rot(u):rot(f);
if(target==nil) rt=u;
}
inline void del(node*u) {
splay(u,nil);
pushdown(u);
if(u->ch[0]==nil) rt=u->ch[1],rt->fa=nil;
else {
node*v=u->ch[0];
for(pushdown(v);v->ch[1]!=nil;pushdown(v=v->ch[1]));
splay(v,u);
if((v->ch[1]=u->ch[1])!=nil)v->ch[1]->fa=v;
v->fa=nil; maintain(rt=v);
}
}
node*build(int l,int r) {
if(l>r)return nil;
int m=l+r>>1;
node*u=cnode++;
mp[rk[m]]=u;
if((u->ch[0]=build(l,m-1))!=nil)u->ch[0]->fa=u;
if((u->ch[1]=build(m+1,r))!=nil)u->ch[1]->fa=u;
maintain(u);
}
int main() {
int n,i;
scanf("%d",&n);
for(i=1;i<=n;++i)scanf("%d",&pr[i].first),pr[i].second=i;
sort(pr+1,pr+n+1);
for(i=1;i<=n;++i)rk[pr[i].second]=i;
rk[n+1]=n+1;
nil=cnode++;
nil->ch[0]=nil->ch[1]=nil->fa=nil;
nil->s=nil->ly=0;
rt=build(0,n+1); rt->fa=nil;
for(i=1;i<=n;++i) {
splay(mp[i],nil);
printf("%d ",rt->ch[0]->s+i-1);
reverse(rt->ch[0]);
del(rt);
}return 0;
}

数组写法在bzoj也AC了。

#include <cstdio>
#include <algorithm>
using namespace std;
inline int gi() {
static int a; static char c;
while(c=getchar(),c<'0');a=c-'0';
while(c=getchar(),'-'<c)a=(a<<3)+(a<<1)+c-'0';
return a;
}
#define N 100010
int fa[N],ch[2][N],s[N],rt;
bool flag[N]; pair<int,int>a[N];
inline void reverse(const int&u) {flag[u]^=1; swap(ch[0][u],ch[1][u]);}
inline void down(const int&u) {
if(!flag[u])return;
flag[u]=false;
if(ch[0][u])reverse(ch[0][u]);
if(ch[1][u])reverse(ch[1][u]);
}
inline void up(const int&u) {s[u]=1+s[ch[0][u]]+s[ch[1][u]];}
inline void rot(const int&u) {
static int f,d,t;
f=fa[u],d=u==ch[1][f];
down(f),down(u);
(t=ch[d][f]=ch[d^1][u])?fa[t]=f:0;
(t=fa[u]=fa[f])?ch[f==ch[1][t]][t]=u:0;
fa[f]=u,ch[d^1][u]=f;
up(f),up(u);
}
inline void splay(int u,const int&target) {
for(int t;fa[u]^target;rot(u))
if(fa[t=fa[u]]^target) ((u==ch[1][t])^(t==ch[1][fa[t]]))?rot(u):rot(t);
if(!target) rt=u;
}
inline void del(int u) {
splay(u,0); down(u);
if(!ch[0][u]||!ch[1][u])fa[rt=ch[0][u]+ch[1][u]]=0;
else {
int t=ch[0][u];
for(down(t);ch[1][t];down(t))t=ch[1][t];
splay(t,u);
fa[ch[1][t]=ch[1][u]]=t;
fa[t]=0; rt=t;
up(t);
}
}
int build(int l,int r) {
if(l>r) return 0;
int m=l+r>>1;
s[m]=r-l+1;
if(ch[0][m]=build(l,m-1))fa[ch[0][m]]=m;
if(ch[1][m]=build(m+1,r))fa[ch[1][m]]=m;
return m;
}
int main() {
register int n=gi(),i;
for(i=1;i<=n;++i)a[i].first=gi(),a[i].second=i;
sort(a+1,a+n+1);
rt=build(1,n);
for(i=1;i<=n;++i) {
splay(a[i].second,0);
reverse(ch[0][rt]);
printf("%d ",s[ch[0][rt]]+i);
del(rt);
}
return 0;
}

bzoj3506 [Cqoi2014]排序机械臂的更多相关文章

  1. BZOJ1552[Cerc2007]robotic sort&BZOJ3506[Cqoi2014]排序机械臂——非旋转treap

    题目描述 输入 输入共两行,第一行为一个整数N,N表示物品的个数,1<=N<=100000. 第二行为N个用空格隔开的正整数,表示N个物品最初排列的编号. 输出 输出共一行,N个用空格隔开 ...

  2. [BZOJ3506] [Cqoi2014] 排序机械臂 (splay)

    Description 同OJ1552 Input Output Sample Input Sample Output HINT Source Solution Q:哎不是同一道题吗为什么分两篇博客来 ...

  3. [bzoj1552][Cerc2007]robotic sort&&[bzoj3506][Cqoi2014]排序机械臂

    非常垃圾的一道平衡树,结果被日了一天.很难受嗷嗷嗷 首先不得不说网上的题解让我这个本来就不熟悉平衡树的彩笔很难受——并不好理解. 还好Sinogi大佬非常的神,一眼就切掉了,而且用更加美妙的解法. 题 ...

  4. 【BZOJ3506】[CQOI2014] 排序机械臂(Splay)

    点此看题面 大致题意: 给你\(n\)个数.第一次找到最小值所在位置\(P_1\),翻转\([1,P_1]\),第二次找到剩余数中最小值所在位置\(P_2\),翻转\([2,P_2]\),以此类推.求 ...

  5. 【BZOJ3506】排序机械臂(Splay)

    [BZOJ3506]排序机械臂(Splay) 题面 神TMBZOJ没有题面,感谢SYC的题面 洛谷的题面也不错 题解 对于每次旋转的物体 显然可以预处理出来 现在只要模拟旋转操作就行了 至于在哪里放标 ...

  6. P3165 [CQOI2014]排序机械臂

    题目描述 为了把工厂中高低不等的物品按从低到高排好序,工程师发明了一种排序机械臂.它遵循一个简单的排序规则,第一次操作找到高度最低的物品的位置 P1P_1P1​ ,并把左起第一个物品至 P1P_1P1 ...

  7. 洛谷P3165 [CQOI2014]排序机械臂

    题目描述 为了把工厂中高低不等的物品按从低到高排好序,工程师发明了一种排序机械臂.它遵循一个简单的排序规则,第一次操作找到摄低的物品的位置P1,并把左起第一个至P1间的物品反序:第二次找到第二低的物品 ...

  8. BZOJ3506/1502 [CQOI2014]排序机械臂

    传送门 依然是一道splay的区间操作,需要注意的是要把下标离散化后来表示splay的节点,我不知道怎么搞所以索性弄了个$ValuetoNode$,看样子没什么问题, 感觉他那个传下标的方法太暴力了. ...

  9. Luogu P3165 [CQOI2014]排序机械臂

    先讲一下和这题一起四倍经验的题: Luogu P4402 [Cerc2007]robotic sort 机械排序 SP2059 CERC07S - Robotic Sort UVA1402 Robot ...

随机推荐

  1. Android界面架构(Activity,PhoneWiondow,DecorView)简介

    在一个Android应用程序中,用户界面通过View和ViewGroup对象构建.所有View的子类成为"Widget",所有ViewGroup的子类成为"Layout& ...

  2. Unity插件之Unity调用C#编译的DLL

    Unity插件分为两种:托管插件(Managed Plugins)和本地插件(Native Plugins).本文先来说说Unity中的托管插件,本地插件的文章留到下一篇文章再说. 有时候我们会有这样 ...

  3. git与github安装、配置、pull、push

    操作系统是Ubuntu 16.04 LTS 64bit 1 安装git (1)安装 sudo apt-get install git-core (2)一些全局变量的初始化 在本地建立一个文件夹,然后做 ...

  4. (八)数据呈现——一图胜千言<完结>

    数据分析师就像厨师一样.厨师的工作有5步:下单.备料.切配.烹饪.打荷.数据分析师的工作也有5步.呈现数据就好像打荷.厨师在把菜肴端给客人之前要做盘饰美化,让菜肴精致美观,这个工作就是打荷.同样,数据 ...

  5. MySQL同步常见问题解答(自己的小心得)

    前几天刚刚注册了博客园,我想写一些技巧性的教程,今天给大家分享一个MySQL同步常见问题解答. Q:如果主服务器正在运行并且不想停止主服务器,怎样配置一个从服务器? A:有多种方法.如果你在某时间点做 ...

  6. MySQL学习笔记

    数据库 P3306create database [if not exists] db_name [characterset gbk];use database;//跳转数据库show databas ...

  7. 前端编辑工具之VSCode

      因为前段时间看了瞬息之间的一篇文章编辑器背后的程序观, 里面只提到了Visual studio. 我想想可能是因为非.Net开发者,所以不知道Visual sutdio code这个工具.来看看V ...

  8. springMVC异常&&重定向&&转发

    SpringMVC核心技术---转发和重定向 当处理器对请求处理完毕后,向其他资源进行跳转时,有两种跳转方式:请求转发与重定向.而根据要跳转的资源类型,又可分为两类:跳转到页面与跳转到其他处理器.对于 ...

  9. [No000092]SVN学习笔记3-Import/Checkout(迁入/迁出),GetLock(加锁)

    一.TortoiseSVN Client 获取服务器端的文件到新的本地文件夹 1.在本地新文件夹上右键菜单: 2.打开Repo-browser(可能需要输入你的用户名&密码) 3.输入服务器端 ...

  10. Node6.9.2 —— Http官网笔记整理

    欢迎指导与讨论 : ) 序章 本文概要:http.Agent代理.http.ClientRequest客户端请求.http.server服务器.http.ServerResponse服务器相应.htt ...