HDU 4286 Data Handler 双向链表/Splay
Data Handler
Time Limit: 20 Sec
Memory Limit: 256 MB
题目连接
http://acm.hdu.edu.cn/showproblem.php?pid=4286
Description
In one day, the company gives you many commands to handle these data, so you should finish them one by one. At the beginning, there are N data, and hand "L" and "R" are in some positions. Each command is one the following formats:
(1)MoveLeft L/R: it means that you should move the hand "L"/"R" left one data unit;
(2)MoveRight L/R: it means that you should move the hand "L"/"R" right one data unit;
(3)Insert L X: it means that you should insert the data that contains X at the right of the hand "L";
(4)Insert R X: it means that you should insert the data that contains X at the left of the hand "R";
(5)Delete L: it means that you should delete the one data at the right of the hand "L";
(6)Delete R: it means that you should delete the one data at the left of the hand "R";
(7)Reverse: it means that you should reverse all the data between hand "L" and hand "R".
After finish all the commands, you should record all the data from left to right. So please do it.
Input
The first line contains an integer T(1<=T<=10), the number of test cases.
Then T test cases follow. For each test case, the first line contains an integer N(1<=N<=500000), the number of data at the beginning. The second line contains N integers, means the integer in each data, from left to right. The third line contains two integers L and R (1<=L<=R<=N), the positions of hand "L" and hand "R". It means that hand "L" is at the left of the L-th data and hand "R" is at the right of the R-th data. The fourth line contains one integer M(1<=M<=500000), the number of commands. Then M lines follow, each line contains a command in the above format. All the integers in the data will in range [-10000,10000].
It is guaranteed that there are always some data between hand "L" and "R", and if the hand is at the left/right end of the data line, it will not receive the command MoveLeft/MoveRight.
Because of large input, please use scanf instead of cin.
Output
For each test case, output the integers in the data from left to right in one line, separated in a single space.
Because of large output, please use printf instead of cout.
Sample Input
2
5
1 2 3 4 5
1 5
5
MoveLeft R
Insert R 6
Reverse
Delete R
Insert L 7
5
6536 5207 2609 6604 -4046
1 3
5
Delete L
Insert R -9221
Reverse
Delete L
MoveRight L
Sample Output
7 6 4 3 2 5
2609 5207 6604 -4046
HINT
题意
翻转,删除,插入操作
题解:
splay或者双端队列,但是我智商太低了,所以splay过不了
代码
#include<cstdio>
#include<cstring>
using namespace std;
struct node
{
int value;
int pre,next;
} num[];
int l,ll,r,rr,cnt;
void MoveLefe()
{
char ch[];
scanf("%s",ch);
if(ch[]=='L')
{
if(num[ll].pre==l)
{
l=ll;
ll=num[ll].next;
}
else
{
l=ll;
ll=num[ll].pre;
}
}
else
{
if(num[r].pre==rr)
{
rr=r;
r=num[r].next;
}
else
{
rr=r;
r=num[r].pre;
}
}
}
void MoveRight()
{
char ch[];
scanf("%s",ch);
if(ch[]=='L')
{
if(num[l].pre==ll)
{
ll=l;
l=num[l].next;
}
else
{
ll=l;
l=num[l].pre;
}
}
else
{
if(num[rr].pre==r)
{
r=rr;
rr=num[rr].next;
}
else
{
r=rr;
rr=num[rr].pre;
}
}
}
void Insert()
{
char ch[];
int value;
scanf("%s%d",ch,&value);
if(ch[]=='L')
{
num[cnt].pre=ll;
num[cnt].next=l;
if(num[ll].pre==l) num[ll].pre=cnt;
else num[ll].next=cnt;
if(num[l].pre==ll) num[l].pre=cnt;
else num[l].next=cnt;
l=cnt++;
num[l].value=value;
}
else
{
num[cnt].pre=rr;
num[cnt].next=r;
if(num[rr].pre==r) num[rr].pre=cnt;
else num[rr].next=cnt;
if(num[r].pre==rr) num[r].pre=cnt;
else num[r].next=cnt;
r=cnt++;
num[r].value=value;
}
}
void Delete()
{
char ch[];
int next;
scanf("%s",ch);
if(ch[]=='L')
{
if(num[l].pre==ll) next=num[l].next;
else next=num[l].pre;
if(num[ll].pre==l) num[ll].pre=next;
else num[ll].next=next;
if(num[next].pre==l) num[next].pre=ll;
else num[next].next=ll;
l=next;
}
else
{
if(num[r].pre==rr) next=num[r].next;
else next=num[r].pre;
if(num[rr].pre==r) num[rr].pre=next;
else num[rr].next=next;
if(num[next].pre==r) num[next].pre=rr;
else num[next].next=rr;
r=next;
}
}
void Reverse()
{
if(num[r].pre==rr) num[r].pre=ll;
else num[r].next=ll;
if(num[l].pre==ll) num[l].pre=rr;
else num[l].next=rr;
if(num[ll].pre==l) num[ll].pre=r;
else num[ll].next=r;
if(num[rr].pre==r) num[rr].pre=l;
else num[rr].next=l;
l=l^r;
r=l^r;
l=l^r;
}
void out(int n)
{
bool first=true;
int pre=;
for(int i=num[].next;i!=n+;)
{
if(first)
{
printf("%d",num[i].value);
first=false;
}
else printf(" %d",num[i].value);
if(num[i].next!=pre)
{
pre=i;
i=num[i].next;
}
else
{
pre=i;
i=num[i].pre;
}
}
printf("\n");
}
int main()
{
int cas,n,m;
char s[];
scanf("%d",&cas);
for(; cas--;)
{
scanf("%d",&n);
cnt=n+;
for(int i=; i<=n; ++i)
{
scanf("%d",&num[i].value);
num[i].pre=i-;
num[i].next=i+;
}
scanf("%d%d",&l,&r);
num[].pre=;
num[].next=;
num[n+].pre=n;
ll=num[l].pre;
rr=num[r].next;
scanf("%d",&m);
for(; m--;)
{
scanf("%s",s);
if(strcmp(s,"MoveLeft")==)
MoveLefe();
else if(strcmp(s,"MoveRight")==)
MoveRight();
else if(strcmp(s,"Insert")==)
Insert();
else if(strcmp(s,"Delete")==)
Delete();
else if(strcmp(s,"Reverse")==)
Reverse();
}
out(n);
}
return ;
}
HDU 4286 Data Handler 双向链表/Splay的更多相关文章
- HDU 4286 Data Handler --双端队列
题意:有一串数字,两个指针,然后一些添加,删除,反转,以及移动操作,最后输出序列. 解法:可以splay做,但是其实双端队列更简便. 维护三个双端队列LE,MI,RI分别表示[L,R]序列左边,[L, ...
- BZOJ 1588: [HNOI2002]营业额统计 双向链表 / splay / treap
1588: [HNOI2002]营业额统计 Description 营业额统计 Tiger最近被公司升任为营业部经理,他上任后接受公司交给的第一项任务便是统计并分析公司成立以来的营业情况. Tiger ...
- HDU 4453:Looploop(Splay各种操作)
http://acm.hdu.edu.cn/showproblem.php?pid=4453 题意:很多种操作:1.add x,将从光标起的 k2 个数全部加上 x:2.reverse,将从光标起的 ...
- HDU 4441 Queue Sequence(splay)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4441 题意:一个数列,三种操作:(1)插入:找到没在当前数列中的最小的正整数i,将其插在位置p之后,并 ...
- HDU 1890 Robotic Sort(splay)
[题目链接] http://acm.hdu.edu.cn/showproblem.php?pid=1890 [题意] 给定一个序列,每次将i..P[i]反转,然后输出P[i],P[i]定义为当前数字i ...
- hdu 1754 I Hate It (splay tree伸展树)
hdu 1754 I Hate It 其实我只是来存一下我的splay模板的..请大牛们多多指教 #include<stdio.h> #include<string.h> #i ...
- HDU 3487 Play with Chain | Splay
Play with Chain Time Limit: 6000/2000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) ...
- HDU 2217 Data Structure?
C - Data Structure? Time Limit:5000MS Memory Limit:65536KB 64bit IO Format:%I64d & %I64u ...
- hdu 1890 Robotic SortI(splay区间旋转操作)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1890 题解:splay又一高级的功能,区间旋转这个是用线段树这些实现不了的,这题可以学习splay的旋 ...
随机推荐
- pdm 中怎么修改表的Name值时使Code值不变
修改方法:PowerDesign中的选项菜单里修改,在[Tool]-->[General Options]->[Dialog]->[Operating modes]->[Nam ...
- APP测试时不可忽视搭建代理服务器抓包测试的必要性
这几天测的一个app,后台从已有服务器搬迁到了阿里云,接口api之类的都没有变化,但测试时发现客户端始终无法使用,每次点击都无法获得服务器反馈 用python编写脚本调接口,没问题,返回数据一切正常, ...
- 原生JS取代一些JQuery方法
1.选取元素 // jQuery var els = $('.el'); // Native var els = document.querySelectorAll('.el'); // Shorth ...
- JavaScript的function对象
我必须先说Java与JavaScript没有关系,不是我以前想的那个样子的(JavaScript是Java的一种超进化) 在JavaScript中,函数(function)就是对象. JavaScri ...
- 非对称认证方式 可以用在 asp.net webapi 的安全机制里面
//Client端调用 static void Main(string[] args) { string publicKey = "DpLMCOihcYI2i6DaMbso9Dzo1miy7 ...
- C#获取文件的绝对路径
要在c#中获取路径有好多方法,一般常用的有以下五种: //获取应用程序的当前工作目录. String path1 = System.IO.Directory.GetCurrentDirectory() ...
- dom 表格操作
<!doctype html> <html> <head> <meta charset="utf-8"> <title> ...
- 第二百一十一天 how can i 坚持
参与感.做项目要有激情. 睡觉.
- jbpm4.4+ssh配置(有些使用经验很好)
http://www.cnblogs.com/cmzcheng/archive/2011/11/20/2255806.html ———————————————————————————————————— ...
- 使用「max-height」实现自适应高度
.tab-content{ max-height: 0; overflow: hidden; -webkit-transition: max-height .8s; -moz-transition: ...