【Luogu】P1383高级打字机

可持久化线段树模板题之一。

权当温习主席树模板

#include<cstdio>
#include<cstdlib>
#include<cctype>
#define left (rt<<1)
#define right (rt<<1|1)
#define mid ((l+r)>>1)
#define lson l,mid,left
#define rson mid+1,r,right

inline long long read(){
    long long num=0,f=1;
    char ch=getchar();
    while(!isdigit(ch)){
        if(ch=='-')    f=-1;
        ch=getchar();
    }
    while(isdigit(ch)){
        num=num*10+ch-'0';
        ch=getchar();
    }
    return num*f;
}


int root[2000000];
int ls[2000000];
int rs[2000000];
char tree[2000000];
int len[2000000];
int ID;
void add(int l,int r,int &rt,char x,int pos,int last){
    rt=++ID;
    if(l==r){
        tree[rt]=x;
        return;
    }
    ls[rt]=ls[last];
    rs[rt]=rs[last];
    if(pos<=mid)    add(l,mid,ls[rt],x,pos,ls[last]);
    else             add(mid+1,r,rs[rt],x,pos,rs[last]);
}

int query(int pos,int l,int r,int rt){
    if(l==r)    return rt;
    if(pos<=mid)    return query(pos,l,mid,ls[rt]);
    else             return query(pos,mid+1,r,rs[rt]);
}

int now;

int main(){
    int n=read();
    for(int i=1;i<=n;++i){
        char ch[10];int x;
        scanf("%s",ch);
        if(ch[0]=='Q'){
            x=read();
            int pos=query(x,1,n,root[now]);
            printf("%c\n",tree[pos]);
        }
        else if(ch[0]=='U'){
            x=read();
            now++;
            len[now]=len[now-x-1];
            root[now]=root[now-x-1]; 
        }
        
        else{
            char c[10];
            scanf("%s",c);
            now++;len[now]=len[now-1]+1;
            add(1,n,root[now],c[0],len[now],root[now-1]);
        }
    }
    return 0;
}
            
    

 

转载于:https://www.cnblogs.com/cellular-automaton/p/7509828.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值