数据结构:双链表

数据结构:双链表

题目描述

输入样例

复制代码
10
R 7
D 1
L 3
IL 2 10
D 3
IL 2 7
L 8
R 9
IL 4 7
IR 2 2

输出样例

复制代码
8 7 7 3 2 9

参考代码

cpp 复制代码
#include <iostream>

using namespace std;

const int N = 100010;

int m;
int idx, e[N], l[N], r[N];

void init()
{
    r[0] = 1;
    l[1] = 0;
    idx = 2;
}

void insert(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)
{
    l[r[k]] = l[k];
    r[l[k]] = r[k];
}

int main()
{
    init();
    
    cin >> m;
    while (m--)
    {
        int k, x;
        string op;
        cin >> op;
        if (op == "L")
        {   
            cin >> x;
            insert(0, x);
        }
        else if (op == "R")
        {
            cin >> x;
            insert(l[1], x);
        }
        else if (op == "D")
        {   
            cin >> k;
            remove(k + 1);
        }
        else if (op == "IL")
        {
            cin >> k >> x;
            insert(l[k + 1], x);
        }
        else
        {
            cin >> k >> x;
            insert(k + 1, x);
        }
    }
    for (int i = r[0]; i != 1; i = r[i]) cout << e[i] << ' ';
    cout << endl;
    
    return 0;
}
相关推荐
智者知已应修善业3 分钟前
【51单片机调用__TIME__无法实时时间】2023-7-10
c++·经验分享·笔记·算法·51单片机
北顾笙9808 分钟前
day29-数据结构力扣
数据结构
凤凰院凶涛QAQ12 分钟前
《C++转JAVA快速入手系列》:基本通用语法篇
java·开发语言·c++
Shadow(⊙o⊙)29 分钟前
C++常见错误解析2.0
开发语言·数据结构·c++·后端·学习·算法
欧米欧40 分钟前
STRING的底层实现
前端·c++·算法
数智化精益手记局40 分钟前
4m变更管理实战:拆解4m变更管理四大要素的管控功能与常见难题
大数据·数据结构·数据库·人工智能·精益工程
南境十里·墨染春水1 小时前
C++流类库 字符串流
开发语言·c++
agilearchitect1 小时前
Matlab导入Excel表格教程:从基础到进阶全攻略
数据结构·其他·matlab·excel
code_whiter1 小时前
C++9(vector)
开发语言·c++
xieliyu.1 小时前
Java手搓数据结构:从零模拟实现单向无头非循环链表
java·数据结构·学习·链表