博客园 首页 私信博主 显示目录 隐藏目录 管理 动画

bzoj 3223: Tyvj 1729 文艺平衡树

Description

 

您需要写一种数据结构(可参考题目标题),来维护一个有序数列,其中需要提供以下操作:翻转一个区间,例如原有序序列是5 4 3 2 1,翻转区间是[2,4]的话,结果是5 2 3 4 1 

Input

第一行为n,m n表示初始序列有n个数,这个序列依次是(1,2……n-1,n)  m表示翻转操作次数
接下来m行每行两个数[l,r] 数据保证 1<=l<=r<=n 

 

Output

 

输出一行n个数字,表示原始序列经过m次变换后的结果 

 

Sample Input

5 3

1 3

1 3

1 4

Sample Output

4 3 2 1 5

HINT

 



N,M<=100000

 
 
 
头一回写SPLAY的翻转……不用考虑优先级什么的,翻[l,r]的时候就把l-1和r+1挪出来,中间那串就交换左右儿子就行了(其实位置就是key)
 
#include<cstdio>
#include<cstdlib>
#include<algorithm>
using namespace std;

int n,m,l,r,p,ch;
inline int read(){
    p=0;ch=getchar();
    while(ch<'0'||ch>'9') ch=getchar();
    while(ch>='0'&&ch<='9') p=p*10+ch-48,ch=getchar();
    return p;
}
struct tree{
    int l,r,k,f,s;
    bool bo;
    tree(){
        bo=f=l=r=0;
    }
};
struct splay_tree{
    int size,root;
    tree t[100001];
    splay_tree(){
        size=0;root=0;
    }
    inline void ler(int &p){
        int k=t[p].r;
        t[k].f=t[p].f;
        t[p].f=k;
        t[t[k].l].f=p;
        t[p].r=t[k].l;
        t[k].l=p;
        t[k].s=t[p].s;
        t[p].s=t[t[p].l].s+t[t[p].r].s+1;
        p=k;
    }
    inline void rir(int &p){
        int k=t[p].l;
        t[k].f=t[p].f;
        t[p].f=k;
        t[t[k].r].f=p;
        t[p].l=t[k].r;
        t[k].r=p;
        t[k].s=t[p].s;
        t[p].s=t[t[p].l].s+t[t[p].r].s+1;
        p=k;
    }
    inline void ph(int &x,bool bo){
        if (bo) rir(x);else ler(x);
    }
    inline bool getc(int x){
        return t[t[x].f].l==x;
    }
    inline void rot(int l){
        if (t[l].f==root) ph(root,getc(l));else
        if (getc(t[l].f)) ph(t[t[t[l].f].f].l,getc(l));else ph(t[t[t[l].f].f].r,getc(l));
    }
    inline void splay(int l,int f){
        while (t[l].f!=f){
            if (t[t[l].f].f==f) rot(l);else
            if (getc(l)==getc(t[l].f)) rot(t[l].f),rot(l);else rot(l),rot(l);
        }
    }
    inline void build(int &p,int l,int r){
        if (l>r) return;
        p=++size;
        int mid=(l+r)>>1;
        t[p].k=mid;
        build(t[p].l,l,mid-1);
        build(t[p].r,mid+1,r);
        t[t[p].l].f=t[t[p].r].f=p;
        t[p].s=1+t[t[p].l].s+t[t[p].r].s;
    }
    inline void pd(int x){
        if (t[x].bo){
            t[t[x].l].bo^=1;t[t[x].r].bo^=1;
            t[x].bo=0;
            swap(t[x].l,t[x].r);
        }
    }
    inline int find(int x,int y){
        pd(x);
        if (t[t[x].l].s<y-1) return find(t[x].r,y-1-t[t[x].l].s);
        if (t[t[x].l].s==y-1) return x;
        return find(t[x].l,y);
    }
    inline void dfs(int x){
        if (!x) return;
        pd(x);
        dfs(t[x].l);if (t[x].k!=0&&t[x].k<=n)printf("%d ",t[x].k);dfs(t[x].r);
    }
};
splay_tree t;
int main(){
    n=read();m=read();
    t.build(t.root,0,n+1);
    while(m--){
        l=read();r=read();
        l=t.find(t.root,l);r=t.find(t.root,r+2);
        t.splay(l,0);t.splay(r,l);
        t.t[t.t[r].l].bo^=1;
    }
    t.dfs(t.root);
}

 

 
posted @ 2016-02-26 14:19  swm_sxt  阅读(155)  评论(0编辑  收藏  举报