模板_SPLAY

#include<bits/stdc++.h>
#define maxn 500005
//#define int long long
using namespace std;
inline int read()
{
    char x = getchar();
    int lin = 0, f = 1;
    while(x < '0' || x > '9')
    {
        if(x == '-') f = -1;
        x = getchar();
    }
    while(x >= '0' && x <= '9')
    {
        lin = (lin << 1) + (lin << 3) + x - '0';
        x = getchar();
    }
    return lin * f;
}
#define PII pair<int,int>
#define fir first
#define sec second
#define ma(a,b) make_pair(a,b)
#define db double
#define inf 123123123
int son[maxn][2],fa[maxn],v[maxn],rev[maxn],sz[maxn];
int rt,n,m,a[maxn],ty,le,re,tot;
#define l son[x][0]
#define r son[x][1]
void revl(int x) { swap(l,r); rev[x] ^= 1; }
bool get(int x) { return son[fa[x]][1] == x; }
void pb(int x) { if(rev[x]) { revl(l); revl(r); rev[x] = 0; } }
void link(int now,int F,int t) { fa[now] = F; son[F][t] = now; }
void update(int x) { sz[x] = 1; if(l) sz[x] += sz[l]; if(r) sz[x] += sz[r]; }
void rotate(int x,int &k)
{
    int y = fa[x],z = fa[y],t = get(x);
    if(k == y) k = x;
    else son[z][get(y)] = x;
    link(son[x][t ^ 1],y,t); link(y,x,t ^ 1);
    fa[x] = z;
    update(y);
    update(x);
}
void splay(int x,int &k)
{
    while(x != k)
    {
        int y = fa[x];
        if(y != k)
            if(get(x) == get(y)) rotate(x,k);
            else rotate(y,k);
        rotate(x,k);
    }
}
int find(int x,int k)
{
    pb(x);
    if(sz[l] + 1 == k) return x;
    if(sz[l] + 1 < k) return find(r,k - sz[l] - 1);
    return find(l,k);
}
int split(int x,int y)
{
    x = find(rt,x);
    y = find(rt,y + 2);
    splay(x,rt); splay(y,r);
    return son[y][0];
}
int build(int le,int re,int F)
{
    ++tot;
    int x = tot;
    fa[x] = F;
    int mid = le + re >> 1;
    v[x] = a[mid];
    if(le < mid) l = build(le,mid - 1,x);
    if(re > mid) r = build(mid + 1,re,x);
    update(x);
    return x;
}
void reverse(int x,int y) { revl(split(x,y)); }
void print(int x)
{
    pb(x);
    if(l) print(l);
    if(v[x] != inf) printf("%d ",v[x]);
    if(r) print(r);
}
signed main(){
    n = read(); m = read();
    for(int i = 1; i <= n; i++) a[i + 1] = i;
    a[1] = a[n + 2] = inf;
    rt = build(1,n + 2,0);
    for(int i = 1; i <= m; i++)
    {
        le = read(); re = read();
        reverse(le,re);
    }
    print(rt);
}

 

posted @ 2018-11-07 14:21  cc123321  阅读(213)  评论(0编辑  收藏  举报