Data Handler

Time Limit: 20 Sec

Memory Limit: 256 MB

题目连接

http://acm.hdu.edu.cn/showproblem.php?pid=4286

Description

You are in charge of data in a company, so you are called "Data Handler". Different from the data in computer, the data you have are really in huge volume, and each data contains only one integer. All the data are placed in a line from left to right. There are two "hand" to handle the data, call hand "L" and hand "R". Every hand is between two adjacent data or at the end of the data line.
  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的更多相关文章

  1. HDU 4286 Data Handler --双端队列

    题意:有一串数字,两个指针,然后一些添加,删除,反转,以及移动操作,最后输出序列. 解法:可以splay做,但是其实双端队列更简便. 维护三个双端队列LE,MI,RI分别表示[L,R]序列左边,[L, ...

  2. BZOJ 1588: [HNOI2002]营业额统计 双向链表 / splay / treap

    1588: [HNOI2002]营业额统计 Description 营业额统计 Tiger最近被公司升任为营业部经理,他上任后接受公司交给的第一项任务便是统计并分析公司成立以来的营业情况. Tiger ...

  3. HDU 4453:Looploop(Splay各种操作)

    http://acm.hdu.edu.cn/showproblem.php?pid=4453 题意:很多种操作:1.add x,将从光标起的 k2 个数全部加上 x:2.reverse,将从光标起的 ...

  4. HDU 4441 Queue Sequence(splay)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4441 题意:一个数列,三种操作:(1)插入:找到没在当前数列中的最小的正整数i,将其插在位置p之后,并 ...

  5. HDU 1890 Robotic Sort(splay)

    [题目链接] http://acm.hdu.edu.cn/showproblem.php?pid=1890 [题意] 给定一个序列,每次将i..P[i]反转,然后输出P[i],P[i]定义为当前数字i ...

  6. hdu 1754 I Hate It (splay tree伸展树)

    hdu 1754 I Hate It 其实我只是来存一下我的splay模板的..请大牛们多多指教 #include<stdio.h> #include<string.h> #i ...

  7. HDU 3487 Play with Chain | Splay

    Play with Chain Time Limit: 6000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) ...

  8. HDU 2217 Data Structure?

    C - Data Structure? Time Limit:5000MS     Memory Limit:65536KB     64bit IO Format:%I64d & %I64u ...

  9. hdu 1890 Robotic SortI(splay区间旋转操作)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1890 题解:splay又一高级的功能,区间旋转这个是用线段树这些实现不了的,这题可以学习splay的旋 ...

随机推荐

  1. win 7 下Maven环境的搭建

    Apache Maven,是一个软件(特别是Java软件)项目管理及自动构建工具. Maven是什么? 比较正式的定义:Maven是一个项目管理工具,它包含了: 一个项目对象模型 (Project O ...

  2. Garlands

    题意: n个数分成m段,每段偶数个数,最小化和最大段的半个区间的数字和. 分析: 先想到了二分,dp求能分成的最小段数. #include <map> #include <set&g ...

  3. python发布模块的原理及部分讲解

  4. TopFreeTheme精选免费模板【20130701.特别版】

    今天我们整理了16款WordPress和Joomla的最新主题.它们都是来自Themeforest,RocketTheme,YooTheme以及TemPlaza的高质量主题,赶快收藏起来吧. Este ...

  5. 【Python学习笔记】集合

    概述 集合的一般操作 内建函数进行标准操作集合 数学运算符进行标准操作集合 集合的应用 概述 python的集合(set)是无序不重复元素集,是一种容器.集合(set)中的元素必须是不可变对象,即可用 ...

  6. JAVA逻辑字符串判断真假

    package com.chinahrt.zyn.iteye; import javax.script.Bindings; import javax.script.Compilable; import ...

  7. VS2012打包部署Winform程序

    打包前的准备工作: 新建一个打包部署项目,点OK,如果是第一次使用的话,会打开一个网页,按照提示的步骤来做, 点击上面的step2的网址,进入到另一个网页: 填写完右边的信息,点击“download ...

  8. ets dets

    相同点:ets和dets都提供“键—值”搜索表 不同点:ets驻留在内存,dets驻留在磁盘 特点:ets表和dets表可以被多个进程共享,因此通过这两个模块可以实现数据间的交换 一  ets表 实现 ...

  9. delphi请求idhttp数据

    idhttp ss : TStringStream; begin ss := TStringStream.)); { 指定gb2312的中文代码页,或者54936(gb18030)更好些 utf8 对 ...

  10. Python和Django的Third Libraby分类汇总

    这些第三方包与Python和Django一起构成了强大的生态系统,自己在开发时大大减小工作难度和工作量, 这些包基本上能满足我们的大部分需求.人与人的差距,其中一点是你知道的比他多,这样你就能大大提高 ...