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. MSSQL 查询分组前N条记录

    sql语句中,查询分组中前n条记录的sql语句如下 第一种方法 select * from consultingfeebill awhere n>(select count(*) from co ...

  2. SqlServer 列的增加和删除

    有些时候我们需要删除或增加数据库中有数据中表的列.总结一下列的删除和增加. 1. 删除列 当表中存在数据时,删除列后,数据也会被删除. sql语句: alter table 表名 drop colum ...

  3. php 在线 mysql 大数据导入程序

    1 <?php header("content-type:text/html;charset=utf-8"); error_reporting(E_ALL); set_tim ...

  4. Java核心 --- 泛型

    CoreJava 泛型 java泛型的出现避免了强制类型转换,便于代码更好的被阅读 本文的写作参照了张孝祥的泛型介绍:http://www.itcast.cn/news/dbfd20f1/f4b1/4 ...

  5. Unity 5 引擎收费版和免费版的区别(转)

    最新Unity 5的Professional Edition(收费版)具备全新而强大的功能,除了全局动态光照或是最新的基于物理的着色器之外,也把原本分开销售的Team License放入,并含有12个 ...

  6. 【LeetCode】165 - Compare Version Numbers

    Compare two version numbers version1 and version2.If version1 > version2 return 1, if version1 &l ...

  7. centos6.3 安装配置redis

    1.下载安装 1.1 下载包 注:在http://download.redis.io/releases查询需要下载的版本 wget http://download.redis.io/releases/ ...

  8. CreateThread函数&&CString::GetBuffer函数

    对这个两个常见的windows下的函数学习了一下: //最简单的创建多线程实例 #include <stdio.h> #include <windows.h> //子线程函数 ...

  9. HDU5874:Friends and Enemies

    题目链接: Friends and Enemies 分析: 是一道想法题,我们假设x个人互相敌对,然后有y个人与这x个人都是朋友,而这y个人互相敌对. 则有 x+y=m x*y<=n 举个例子: ...

  10. ajax 瀑布流实现

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...