双链表板子
#include <bits/stdc++.h>
using namespace std;
const int N=100005;
int m,k,x;
int l[N],r[N],e[N],idx;//0最左端,1最右端
char op[4];
void init(){
r[0]=1,l[1]=0,idx=2;
}
void Insert(int k,int x){//在k右边插入一个数
e[idx]=x,l[idx]=k,r[idx]=r[k];
int rr=r[k];
l[rr]=idx,r[k]=idx++;
}
void Delete(int k){//删掉k右边的一个数
int ll=l[k],rr=r[k];
r[ll]=rr,l[rr]=ll;
}
int main(int argc, char** argv) {
cin>>m;
init();
for(int i=0;i<m;i++){
scanf("%s",op);
if(op[0]=='L'){
scanf("%d",&x);
Insert(0,x);
}else if(op[0]=='R'){
scanf("%d",&x);
Insert(l[1],x);
}else if(op[0]=='D'){
scanf("%d",&k);
Delete(k+1);//因为idx即正式链表是从2开始的,所以要k+1
}else if(op[0]=='I'){
scanf("%d%d",&k,&x);//L为左插,R为右插
if(op[1]=='L') Insert(l[k+1],x);//加在左边是逆序,刚做是在这里跌坑
else Insert(k+1,x);//加右边是顺序
}
}
for(int i=r[0];i!=1;i=r[i]){
printf("%d ",e[i]);
}
return 0;
} 
京公网安备 11010502036488号