acwing827双链表,数组模拟链表
双链表板子
#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; }