• 【ACWing 算法基础】双链表(数组模拟双链表)


    一. 模板

    // e[]表示节点的值,l[]表示节点的左指针,r[]表示节点的右指针,idx表示当前用到了哪个节点
    int e[N], l[N], r[N], idx;
    
    // 初始化
    void init()
    {
        //0是左端点,1是右端点
        r[0] = 1, l[1] = 0;
        idx = 2;
    }
    
    // 在节点a的右边插入一个数x
    void insert(int a, int x)
    {
        e[idx] = x;
        l[idx] = a, r[idx] = r[a];
        l[r[a]] = idx, r[a] = idx ++ ;
    }
    
    // 删除节点a
    void remove(int a)
    {
        l[r[a]] = l[a];
        r[l[a]] = r[a];
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25

    二. 总结

    • 插入操作
      在这里插入图片描述
    • 删除操作
      在这里插入图片描述

    三. 例题

    在这里插入图片描述

    AC代码:

    #include 
    #include 
    
    using namespace std;
    
    const int N = 1e5 + 10;
    
    int e[N], l[N], r[N], idx;
    
    
    // 初始化双链表
    void init()
    {
        l[1] = 0, r[0] = 1;  // 将0,1分配给头结点和尾结点,并让他们互相指向对方
        idx = 2;  // 新添加的结点从下标2开始
    }
    
    // 在节点k的右边插入x
    void add(int k, int x)
    {
        e[idx] = x;
        r[idx] = r[k];
        l[idx] = l[r[k]];
        l[r[k]] = idx;
        r[k] = idx++;
    }
    
    // 删除第k个节点
    void remove(int k)
    {
        l[r[k]] = l[k];
        r[l[k]] = r[k];
    }
    
    int main()
    {
        ios::sync_with_stdio(false);
        
        int m;
        cin >> m;
        
        init();  // 初始化别搞忘了!!!
        
        string s;
        int k, x; 
        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);  // k + 1 是因为头节点和尾节点占用了两个,idx从2开始 
            }
            else if (s == "IL") {
                cin >> k >> x;
                add(l[k + 1], x);
            }
            else if (s == "IR") {
                cin >> k >> x;
                add(k + 1, x);
            }
        }
        
        for (int i = r[0]; i != 1; i = r[i])  // 从左向右遍历
            cout << e[i] << ' ';
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    • 65
    • 66
    • 67
    • 68
    • 69
    • 70
    • 71
    • 72
  • 相关阅读:
    高项_第十章项目沟通管理
    中国人民大学与加拿大女王大学金融硕士——热爱会穿越时间,埋在心底的读研梦也是
    日撸 Java 三百行day54-55
    npm发布自己的包
    ITSS认证适用的6大领域范围
    【C++】哈希相关问题
    抖音实战~关注博主
    数据挖掘-06
    NetCore配置详解(2)
    2000亿元贴息贷款,医疗系统上云,解锁医护协同新玩法
  • 原文地址:https://blog.csdn.net/m0_51139226/article/details/126097334