【BZOJ1269/1507】[AHOI2006]文本编辑器editor Splay
【BZOJ1269】[AHOI2006]文本编辑器editor
Description
这些日子,可可不和卡卡一起玩了,原来可可正废寝忘食的想做一个简单而高效的文本编辑器。你能帮助他吗?为了明确任务目标,可可对“文本编辑器”做了一个抽象的定义: 
 
 文本:由0个或多个字符构成的序列。这些字符的ASCII码在闭区间[32, 126]内,也就是说,这些字符均为可见字符或空格。光标:在一段文本中用于指示位置的标记,可以位于文本的第一个字符之前,文本的最后一个字符之后或文本的某两个相邻字符之间。文本编辑器:为一个可以对一段文本和该文本中的一个光标进行如下七条操作的程序。如果这段文本为空,我们就说这个文本编辑器是空的。 编写一个程序: 建立一个空的文本编辑器。 从输入文件中读入一些操作指令并执行。 对所有执行过的GET操作,将指定的内容写入输出文件。
Input
输入文件中第一行是指令条数N,以下是需要执行的N个操作。除了回车符之外,输入文件的所有字符的ASCII码都在闭区间[32, 126]内。且行尾没有空格。
Output
依次对应输入文件中每条GET指令的输出,不得有任何多余的字符。
Sample Input
Insert 13
Balanced eert
Move 2
Delete 5
Next
Insert 7
editor
Move 0
Get
Move 11
Rotate 4
Get
Sample Output
t
HINT
对输入数据我们有如下假定: MOVE操作不超过50 000个,INSERT、DELETE和ROTATE操作作的总个数不超过6 000,GET操作不超过20 000个,PREV和NEXT操作的总个数不超过20 000。 所有INSERT插入的字符数之和不超过2M(1M=1 024*1 024)。 DELETE操作、ROTATE操作和GET操作执行时光标后必然有足够的字符。MOVE、PREV、NEXT操作不会把光标移动到非法位置。 输入文件没有错误。
题解:依旧是Splay裸题,但是有一点很坑:
就是gets()在读入整行时会忽略前导的空格,于是我们必须在读入上一个变量时加一个scanf("%*c")或者getchar()来防止将空格省略掉,或者一个一个字符读进来
#include <cstdio>
#include <cstring>
#include <iostream>
using namespace std;
int n,m,root,now,tot;
struct node
{
int ch[2],fa,v,siz,tag;
}s[1024*2048+10];
char str[1024*2048+10];
void pushup(int x)
{
s[x].siz=s[s[x].ch[0]].siz+s[s[x].ch[1]].siz+1;
}
void pushdown(int x)
{
if(s[x].tag)
{
swap(s[x].ch[0],s[x].ch[1]);
s[s[x].ch[0]].tag^=1,s[s[x].ch[1]].tag^=1;
s[x].tag=0;
}
}
int find(int y,int x)
{
if(!x) return 0;
pushdown(x);
if(s[s[x].ch[0]].siz>=y) return find(y,s[x].ch[0]);
if(s[s[x].ch[0]].siz+1==y) return x;
return find(y-s[s[x].ch[0]].siz-1,s[x].ch[1]);
}
void rotate(int x,int &k)
{
int y=s[x].fa,z=s[y].fa,d=(x==s[y].ch[1]);
if(z) s[z].ch[(y==s[z].ch[1])]=x;
if(y==k) k=x;
s[x].fa=z,s[y].fa=x,s[y].ch[d]=s[x].ch[d^1];
if(s[x].ch[d^1]) s[s[x].ch[d^1]].fa=y;
s[x].ch[d^1]=y;
pushup(y),pushup(x);
}
void splay(int x,int &k)
{
while(x!=k)
{
int y=s[x].fa,z=s[y].fa;
if(y!=k)
{
if((x==s[y].ch[0])^(y==s[z].ch[0])) rotate(x,k);
else rotate(y,k);
}
rotate(x,k);
}
}
void build(int l,int r,int last,int d)
{
if(l>r) return ;
int tmp=++tot,mid=l+r>>1;
s[tmp].fa=last;
s[last].ch[d]=tmp;
s[tmp].v=str[mid]-32;
build(l,mid-1,tmp,0),build(mid+1,r,tmp,1);
pushup(tmp);
}
int main()
{
scanf("%d",&n);
s[1].ch[1]=2,s[1].siz=2,s[2].siz=1,s[2].fa=1,now=root=1,tot=2;
for(int i=1;i<=n;i++)
{
scanf("%s",str);
switch(str[0])
{
case 'M':
{
scanf("%d",&now),now++;
break;
}
case 'I':
{
scanf("%d%*c",&m);
gets(str);
splay(find(now,root),root),splay(find(now+1,root),s[root].ch[1]);
build(0,m-1,s[root].ch[1],0);
pushup(s[root].ch[1]),pushup(root);
break;
}
case 'D':
{
scanf("%d",&m);
splay(find(now,root),root),splay(find(now+m+1,root),s[root].ch[1]);
s[s[root].ch[1]].ch[0]=0;
pushup(s[root].ch[1]),pushup(root);
break;
}
case 'R':
{
scanf("%d",&m);
splay(find(now,root),root),splay(find(now+m+1,root),s[root].ch[1]);
s[s[s[root].ch[1]].ch[0]].tag^=1;
break;
}
case 'G':
{
printf("%c\n",s[find(now+1,root)].v+32);
break;
}
case 'P':
{
now--;
break;
}
case 'N':
{
now++;
break;
}
}
}
return 0;
}
【BZOJ1507】[NOI2003]editor
Description

Input
输入文件editor.in的第一行是指令条数t,以下是需要执行的t个操作。其中: 为了使输入文件便于阅读,Insert操作的字符串中可能会插入一些回车符,请忽略掉它们(如果难以理解这句话,可以参考样例)。 除了回车符之外,输入文件的所有字符的ASCII码都在闭区间[32, 126]内。且行尾没有空格。 这里我们有如下假定:  MOVE操作不超过50000个,INSERT和DELETE操作的总个数不超过4000,PREV和NEXT操作的总个数不超过200000。  所有INSERT插入的字符数之和不超过2M(1M=1024*1024),正确的输出文件长度不超过3M字节。  DELETE操作和GET操作执行时光标后必然有足够的字符。MOVE、PREV、NEXT操作必然不会试图把光标移动到非法位置。  输入文件没有错误。 对C++选手的提示:经测试,最大的测试数据使用fstream进行输入有可能会比使用stdio慢约1秒。
Output
输出文件editor.out的每行依次对应输入文件中每条GET指令的输出。
Sample Input
Insert 26
abcdefghijklmnop
qrstuv wxy
Move 15
Delete 11
Move 5
Insert 1
^
Next
Insert 1
_
Next
Next
Insert 4
.\/.
Get 4
Prev
Insert 1
^
Move 0
Get 22
Sample Output
abcde^_^f.\/.ghijklmno
题解:本题注意事项:
1.读入有换行,要一个一个字符读入
2.网上有人说要防止溢出,感觉没啥用
3.输出时候不要太麻烦哦~
#include <cstdio>
#include <cstring>
#include <iostream>
using namespace std;
int n,m,root,now,tot;
struct node
{
int ch[2],fa,v,siz;
}s[1024*2048+10];
char str[1024*2048+10];
void pushup(int x)
{
s[x].siz=s[s[x].ch[0]].siz+s[s[x].ch[1]].siz+1;
}
int find(int y,int x)
{
if(!x) return 0;
if(s[s[x].ch[0]].siz>=y) return find(y,s[x].ch[0]);
if(s[s[x].ch[0]].siz+1==y) return x;
return find(y-s[s[x].ch[0]].siz-1,s[x].ch[1]);
}
void rotate(int x,int &k)
{
int y=s[x].fa,z=s[y].fa,d=(x==s[y].ch[1]);
if(z) s[z].ch[(y==s[z].ch[1])]=x;
if(y==k) k=x;
s[x].fa=z,s[y].fa=x,s[y].ch[d]=s[x].ch[d^1];
if(s[x].ch[d^1]) s[s[x].ch[d^1]].fa=y;
s[x].ch[d^1]=y;
pushup(y),pushup(x);
}
void splay(int x,int &k)
{
while(x!=k)
{
int y=s[x].fa,z=s[y].fa;
if(y!=k)
{
if((x==s[y].ch[0])^(y==s[z].ch[0])) rotate(x,k);
else rotate(y,k);
}
rotate(x,k);
}
}
void build(int l,int r,int last,int d)
{
if(l>r) return ;
int tmp=++tot,mid=l+r>>1;
s[tmp].fa=last,s[last].ch[d]=tmp,s[tmp].v=str[mid]-32;
build(l,mid-1,tmp,0),build(mid+1,r,tmp,1);
pushup(tmp);
}
void print(int x)
{
if(s[x].ch[0]) print(s[x].ch[0]);
putchar(s[x].v+32);
if(s[x].ch[1]) print(s[x].ch[1]);
}
int main()
{
scanf("%d",&n);
int i,j;
s[1].ch[1]=2,s[1].siz=2,s[2].siz=1,s[2].fa=1,now=root=1,tot=2;
for(i=1;i<=n;i++)
{
scanf("%s",str);
switch(str[0])
{
case 'M':{scanf("%d",&now),now++; break;}
case 'I':
{
scanf("%d%*c",&m);
for(j=0;j<m;j+=(str[j]!='\n'&&str[j]!='\r')) str[j]=getchar();
splay(find(now,root),root),splay(find(now+1,root),s[root].ch[1]);
build(0,m-1,s[root].ch[1],0);
pushup(s[root].ch[1]),pushup(root);
break;
}
case 'D':
{
scanf("%d",&m);
splay(find(now,root),root),splay(find(now+m+1,root),s[root].ch[1]);
s[s[root].ch[1]].ch[0]=0;
pushup(s[root].ch[1]),pushup(root);
break;
}
case 'G':
{
scanf("%d",&m);
splay(find(now,root),root),splay(find(now+m+1,root),s[root].ch[1]);
print(s[s[root].ch[1]].ch[0]);
printf("\n");
break;
}
case 'P':{now--; break;}
case 'N':{now++; break;}
}
}
return 0;
}
【BZOJ1269/1507】[AHOI2006]文本编辑器editor Splay的更多相关文章
- 【bzoj1507】[NOI2003]Editor /【bzoj1269】[AHOI2006]文本编辑器editor  Splay
		
[bzoj1507][NOI2003]Editor 题目描述 输入 输入文件editor.in的第一行是指令条数t,以下是需要执行的t个操作.其中: 为了使输入文件便于阅读,Insert操作的字符串中 ...
 - BZOJ 1269: [AHOI2006]文本编辑器editor( splay )
		
splay..( BZOJ 1507 题目基本相同..双倍经验 ) ------------------------------------------------------------------ ...
 - [bzoj1269][AHOI2006文本编辑器editor] (splay模版题 or pb_ds [rope]大法)
		
Description 这些日子,可可不和卡卡一起玩了,原来可可正废寝忘食的想做一个简单而高效的文本编辑器.你能帮助他吗?为了明确任务目标,可可对“文本编辑器”做了一个抽象的定义: 文本:由0个或 ...
 - [BZOJ1269] [AHOI2006] 文本编辑器editor (splay)
		
Description 这些日子,可可不和卡卡一起玩了,原来可可正废寝忘食的想做一个简单而高效的文本编辑器.你能帮助他吗?为了明确任务目标,可可对“文本编辑器”做了一个抽象的定义: 文本:由0个或多 ...
 - 【BZOJ1269】[AHOI2006] 文本编辑器editor(Splay)
		
点此看题面 大致题意: 让你维护一个字符串,有插入字符串.删除区间.反转区间和输出单个字符操作. \(Splay\) 这应该是一道比较简单的\(Splay\)题(虽然因为各种细节我调了很久). 我们可 ...
 - 【bzoj1269】[AHOI2006]文本编辑器editor
		
在bzoj上乱翻,发现了可持久化并查集,然后baidu了一下,发现一种叫rope的东西. !!!真的太爽了!!! 直接上代码,感受一下(也是蒯来的). 由于rope的底层实现,in ...
 - BZOJ1269 [AHOI2006]文本编辑器editor  【82行splay】
		
1269: [AHOI2006]文本编辑器editor Time Limit: 10 Sec Memory Limit: 162 MB Submit: 4633 Solved: 1782 [Sub ...
 - BZOJ  1269: [AHOI2006]文本编辑器editor (splay tree)
		
1269: [AHOI2006]文本编辑器editor Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1213 Solved: 454[Submit ...
 - BZOJ_1269&&1507_[AHOI2006]文本编辑器editor&&[NOI2003]Editor
		
BZOJ_1269&&1507_[AHOI2006]文本编辑器editor&&[NOI2003]Editor 题意: 分析: splay模拟即可 注意1507的读入格式 ...
 
随机推荐
- 浏览器向下兼容之polyfill[阅后即瞎]
			
我们入门JavaScript的时候都写过polyfill: 比如手写一个弹窗, 手动模拟实现一个表格, 这些魔力的对象都是浏览器原生支持的, 虽然当我成为JS专家之后再也没造过轮子, 但是最近才发现我 ...
 - Java 中的异常和处理详解
			
Java 中的异常和处理详解 原文出处: 代码钢琴家 简介 程序运行时,发生的不被期望的事件,它阻止了程序按照程序员的预期正常执行,这就是异常.异常发生时,是任程序自生自灭,立刻退出终止,还是输出错误 ...
 - Firefox 在LR录制过程中添加例外的问题解决方法
			
用lr调火狐打开网页 会报证书安全问题 证书安全提示目的是告诉你这个服务器使用的证书可能不安全,要不要信任,你自己决定,不信任就不能访问.为什么会报证书安全,因为浏览器没添加该证书.或者由于性能工具 ...
 - 关于Unity中UI中的Image节点以及它的Image组件
			
一.图片的Inspector面板属性 Texture Type:一般是选择sprite(2D and UI) Sprite Mode:一般是选择Single Packing Tag:打包的标志值,最后 ...
 - selenium测试(Java)(三)
			
控制浏览器: http://www.cnblogs.com/moonpool/p/5657752.html
 - android2.2应用开发之IccCard(sim卡或USIM卡)(转至 http://www.2cto.com/kf/201306/223784.html)
			
如果要做android通讯录的联系人的机卡混排显示,由于手机卡类型的不同,导致手机卡存储容量以及可以存储信息不同,就要涉及到android去读Icc卡的信息. 一般的sim卡只能存储姓名跟一个电话号码 ...
 - SVN版本冲突,导致出现Files 的值“ < < < < < < < .mine”无效。路径中具有非法字符。
			
SVN版本冲突,导致出现Files 的值“ < < < < < < < .mine”无效.路径中具有非法字符. 右键编辑.... 打开并删除含有'<&l ...
 - 一个窗口里包含一个iframe,点击iframe内的submit按钮,返回的视图总是显示在iframe中,我想要的效果是点击按钮后返回的视图是在浏览器窗口中...?asp.net mvc 的action中,不用js怎么实现??????????
			
Content("<script type='text/javascript'>parent.location.href = '" + url + "';&l ...
 - jQuery-替换和删除元素
			
1.replaceWith方法 用提供的内容替换集合中所有匹配的元素并且返回被替换元素的集合 参数类型说明: 1)普通字符串(可包含各种html标签) 2)jQuery对象 ①使用$函数创建的新元素( ...
 - 手机web不同屏幕字体大小高度自适应
			
body{font-size:0.6rem:} <script> //使用rem策略,不断更新html的fontsize (function(){ function sizeHtm ...