AcWing 827. 双链表
原题链接
简单
作者:
走不到也得走
,
2020-01-15 00:05:12
,
所有人可见
,
阅读 680
#include<iostream>
#include<string.h>
using namespace std;
const int N=1e5+10;
int e[N],l[N],r[N],idx;
void init()
{
r[0]=1;
l[1]=0;
idx=2;
}
void add(int k,int x)//在右端插入数
{
e[idx]=x;
l[idx]=k;
r[idx]=r[k];
l[r[k]]=idx;
r[k]=idx;;
idx++;
}
void remove(int k)
{
r[l[k]]=r[k];
l[r[k]]=l[k];
}
int main()
{
int m;
cin>>m;
//cout<<m;
init();
while(m--)
{
string op;
cin>>op;
int k,x;
//cout<<op;
if(op=="L"){
cin>>x;
add(0,x);
}
else if(op=="R"){
cin>>x;
add(l[1],x);
}
else if(op=="D"){
cin>>k;
remove(k+1);
}
else if(op=="IL"){
cin>>k>>x;
add(l[k+1],x);
}
else if(op=="IR"){
cin>>k>>x;
add(k+1,x);
}
}
for(int i=r[0];i!=1;i=r[i])
printf("%d ",e[i]);
return 0;
}