双链表板子
#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;
}