紫薯例题

 #include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N=1e6+,inf=0x3f3f3f3f;
int rt[N],siz[N*],ch[N*][],tot,n,d,ver;
char buf[N],val[N*];
#define l(u) ch[u][0]
#define r(u) ch[u][1]
int rnd() {
const int M=(1ll<<)-,X=;
static int seed=time()%M;
return seed=(ll)seed*X%M;
}
int newnode(char c) {int u=++tot; siz[u]=,l(u)=r(u)=,val[u]=c; return u;}
int cpy(int v) {int u=++tot; siz[u]=siz[v],l(u)=l(v),r(u)=r(v),val[u]=val[v]; return u;}
void pu(int u) {siz[u]=siz[l(u)]+siz[r(u)]+;}
void sp(int w,int k,int& u,int& v) {
if(!w) {u=v=; return;}
if(k<=siz[l(w)])v=cpy(w),sp(l(w),k,u,l(v)),pu(v);
else u=cpy(w),sp(r(w),k-(siz[l(w)]+),r(u),v),pu(u);
}
void mg(int& w,int u,int v) {
if(!u||!v) {w=u|v; return;}
if(rnd()%(siz[u]+siz[v])<siz[u])w=u,mg(r(w),r(u),v);
else w=v,mg(l(w),u,l(v));
pu(w);
}
void build(int& u,int l,int r) {
if(l>r) {u=; return;}
int mid=(l+r)>>;
u=newnode(buf[mid]);
build(l(u),l,mid-),build(r(u),mid+,r),pu(u);
}
void ins(int& rt,int p) {
int n=strlen(buf);
int L,M,R;
build(M,,n-);
sp(rt,p,L,R),mg(L,L,M),mg(rt,L,R);
}
void del(int& rt,int p,int c) {
int L,M,R;
sp(rt,p+c-,L,R),sp(L,p-,L,M),mg(rt,L,R);
}
void dfs(int u) {
if(!u)return;
dfs(l(u)),putchar(val[u]),dfs(r(u));
if(val[u]=='c')++d;
}
void pr(int& rt,int p,int c) {
int L,M,R;
sp(rt,p+c-,L,R),sp(L,p-,L,M);
dfs(M),puts("");
mg(L,L,M),mg(rt,L,R);
}
int main() {
scanf("%d",&n);
for(int i=; i<=n; ++i) {
int f;
scanf("%d",&f);
if(f==) {
int p;
scanf("%d%s",&p,buf),p-=d;
++ver,ins(rt[ver]=rt[ver-],p);
} else if(f==) {
int p,c;
scanf("%d%d",&p,&c),p-=d,c-=d;
++ver,del(rt[ver]=rt[ver-],p,c);
} else {
int v,p,c;
scanf("%d%d%d",&v,&p,&c),v-=d,p-=d,c-=d;
pr(rt[v],p,c);
}
}
return ;
}

UVA - 12538 Version Controlled IDE (可持久化treap)的更多相关文章

  1. UVA 12538 Version Controlled IDE 解题报告

    题意:给三种操作 1.在p位置插入一个字符串. 2.从p位置开始删除长度为c的字符串 3.输出第v个历史版本中从p位置开始的长度为c的字符串 解法:可以用平衡树做,但是不会.后来又听说可一用一个叫ro ...

  2. UVALive 6145 Version Controlled IDE(可持久化treap、rope)

    题目链接:https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8&page=show_ ...

  3. UVA12538 Version Controlled IDE

    题意翻译 维护一种数据结构,资磁三种操作. 1.在p位置插入一个字符串s 2.从p位置开始删除长度为c的字符串 3.输出第v个历史版本中从p位置开始的长度为c的字符串 1≤n≤50000,所有字符串总 ...

  4. UVA - 11922 区间反转+拼接 可持久化Treap

    题意:一开始给出一个序列\(1,2...n\),然后\(m\)次操作,每次把\([l,r]\)翻转并且拼接到序列的后面,求最后形成的序列 打个pushdown标记就好 #include<iost ...

  5. BZOJ 3595: [Scoi2014]方伯伯的Oj SBT+可持久化Treap

    3595: [Scoi2014]方伯伯的Oj Time Limit: 6 Sec  Memory Limit: 256 MBSubmit: 102  Solved: 54[Submit][Status ...

  6. 【模板】可持久化文艺平衡树-可持久化treap

    题目链接 题意 对于各个以往的历史版本实现以下操作: 在第 p 个数后插入数 x . 删除第 p 个数. 翻转区间 [l,r],例如原序列是 \(\{5,4,3,2,1\}\),翻转区间 [2,4] ...

  7. 高rong效chang的可持久化treap

    很多人觉得可持久化treap很慢,但是事实上只是他们可持久化treap的写法不对.他们一般是用split和merge实现所有功能,但是这样会有许多不必要的分裂.其实我们可以用一种特殊的方式来实现插入和 ...

  8. 可持久化Treap

    终于写了一次可持久化Treap,做的是可持久化序列的模板题. Treap Treap=Tree+Heap,是一个随机化的数据结构.它的每个节点至少有两个关键字,一个是我们要存储的\(val\),一个是 ...

  9. Codeforces - 38G 可持久化Treap 区间操作

    题意:\(n\)个人排队,每个人有重要度\(p\)和不要脸度\(c\),如果第\(i\)个人的重要度大于第\(i-1\)个人的重要度,那么他们之间可以交换,不要脸度-1,交换后先前的第\(i\)个人也 ...

随机推荐

  1. Java 操作Word表格

    本文将对如何在Java程序中操作Word表格作进一步介绍.操作要点包括 如何在Word中创建嵌套表格. 对已有表格添加行或者列 复制已有表格中的指定行或者列 对跨页的表格可设置是否禁止跨页断行 创建表 ...

  2. React-Native传值方式之 :DeviceEventEmitter添加监听控制并传值到其他页面

    在 native 开发中,我们可以使用广播实现事件的订阅和事件的触发,从而实现不在该页面但是可以调用该页面的方法. 在 React Native 中,我们也可以使用 DeviceEventEmitte ...

  3. 2-0 虚拟机与Linux系统安装

    虚拟机与Linux系统安装 虚拟机硬件选择 由于是初学Linux,所以我们通过在虚拟机里安装的方式学习Linux,如果不知道找虚拟机和Linux的话请看我上一篇博客:计算机基础 如果你已经准备好了虚拟 ...

  4. fiddler的使用:抓包定位、模拟弱网

    一.fiddler抓包定位 Fiddler是一个http协议调试代理工具,它能够记录并检查所有你的电脑和互联网之间的http通讯,设置断点,查看所有的“进出”Fiddler的数据(cookie,htm ...

  5. flask 之(二) --- 视图|模版|模型

    Flask框架 打开pycharm编译器,新建一个Flask项目,选择提前建好的虚拟环境 . 项目结构: static:静态资源文件,可以直接被浏览器访问 templates:模版文件,必须在项目的p ...

  6. "在指定的 DSN 中,驱动程序和应用程序之间的体系结构不匹配" 问题总结

    最近C#连接ODBC数据源时,总是提示"[Microsoft][ODBC 驱动程序管理器] 在指定的 DSN 中,驱动程序和应用程序之间的体系结构不匹配",百度查询之后才知道原来是 ...

  7. Laravel NPM包的使用

    示例:安装sweetalert插件 1.yarn add sweetalert 2.resources/js/bootstrap.js中引入: require('sweetalert'); $(doc ...

  8. 使用 docsify 創建自己的 markdown 文檔系統

    先來看一下我在碼雲上創建的demo: http://lin1270.gitee.io/nicedoc/#/ GIT自己clone一下: https://gitee.com/lin1270/nicedo ...

  9. [转帖]一张图让你看懂InnoDB

    一张图让你看懂InnoDB 2018年05月10日 10:02:34 灵魂自由的忙人 阅读数 299 https://blog.csdn.net/xiaoyi23000/article/details ...

  10. elasticsearch教程--中文分词器作用和使用

    概述   本文都是基于elasticsearch安装教程 中的elasticsearch安装目录(/opt/environment/elasticsearch-6.4.0)为范例 环境准备 ·全新最小 ...