AcWing 827. 双链表
原题链接
简单
作者:
术
,
2021-01-05 19:50:44
,
所有人可见
,
阅读 247
#include <iostream>
using namespace std;
const int N=100005;
int l[N],r[N],e[N];
int idx;
void init(){
idx=2;
r[0]=1;
l[1]=0;
}
void add(int k,int x){
e[idx]=x;
r[idx]=r[k];
l[idx]=k;
l[r[k]]=idx;
r[k]=idx++;
}
void remove(int k){
r[l[k]]=r[k];
l[r[k]]=l[k];
}
int main()
{
int m;
string s;
int k,x;
init();
cin>>m;
while(m--){
cin>>s;
if(s=="L") {
cin>>x;
add(0,x);
}
else if(s=="R"){
cin>>x;
add(l[1],x);
}
else if(s=="D"){
cin>>k;
remove(k+1);
}
else if(s=="IL"){
cin>>k>>x;
add(l[k+1],x);
}
else
{
cin>>k>>x;
add(k+1,x);
}
}
for(int i=r[0];i!=1;i=r[i]) cout<<e[i]<<" ";
return 0;
}