算法刷题笔记 单链表(C++实现)

文章目录

题目描述

实现一个单链表,链表初始为空,支持三种操作:

  1. 向链表头插入一个数;
  2. 删除第 k个插入的数后面的一个数;
  3. 在第 k个插入的数后插入一个数。

现在要对该链表进行M次操作,进行完所有操作后,从头到尾输出整个链表。

注意 :题目中第k个插入的数并不是指当前链表的第k个数。例如操作过程中一共插入了n个数,则按照插入的时间顺序,这n个数依次为:第1个插入的数,第2个插入的数,...第n个插入的数。

输入格式

  • 第一行包含整数M,表示操作次数。
  • 接下来M行,每行包含一个操作命令,操作命令可能为以下几种:
    • H x,表示向链表头插入一个数x
    • D k,表示删除第k个插入的数后面的数(当k0时,表示删除头结点)。
    • I k x,表示在第k个插入的数后面插入一个数x(此操作中k均大于 0)。

输出格式

  • 共一行,将整个链表从头到尾输出。

数据范围

  • 1 ≤ M ≤ 100000
  • 所有操作保证合法。

基本思路

  • 在通常情况下以及我们的课程学习过程中,都是使用一个结构体表示链表结点或完整的链表。但是,这种方式需要每次使用new运算符创建一个新的链表结点,而这实际上是一个非常低效的方式。因此,实际的算法竞赛中,往往使用一个数组或向量来模拟出一个链表,称为静态链表,从而避免低效的动态内存分配。
  • 单链表的实际作用主要是写邻接表,用来存储图和树。

实现代码

cpp 复制代码
#include <iostream>
#include <vector>
using namespace std;

typedef int value;
typedef int pos;
vector< pair<value, pos> > List;

int head = -1;

inline void insert_to_head(const int& x)
{
    List.push_back({x, head});
    head = List.size() - 1;
}

inline void del_after(const int& k)
{
    if(k == 0) head = List[head].second;
    else List[k - 1].second = List[List[k - 1].second].second;
}

inline void insert_after(const int& k, const int& x)
{
    List.push_back({x, List[k - 1].second});
    List[k - 1].second = List.size() - 1;
}

int main(void)
{
    int m;
    cin >> m;
    for(int i = 0; i < m; ++i)
    {
        char operation;
        cin >> operation;
        if(operation == 'H')
        {
            int x;
            cin >> x;
            insert_to_head(x);
        }
        else if(operation == 'D')
        {
            int k;
            cin >> k;
            del_after(k);
        }
        else if(operation == 'I')
        {
            int k, x;
            cin >> k >> x;
            insert_after(k, x);
        }
    }
    while(List[head].second != -1)
    {
        cout << List[head].first << " ";
        head = List[head].second;
    }
    cout << List[head].first << " ";
    return 0;
}

注意事项

  • 这里如果不使用cin进行输入,而是使用scanf函数的话,会出现奇怪的难以解释的错误。因此,以后的算法编程题目中,如果不是输入量特别大的话,都尽量使用更加简单的cin方式进行输入。
相关推荐
2023Fighting几秒前
哈希表(C++实现)
c++·哈希算法·散列表
YmgmY几秒前
推荐算法学习笔记2.2:基于深度学习的推荐算法-基于特征交叉组合+逻辑回归思路的深度推荐算法-Deep Crossing模型
笔记·学习·推荐算法
阑梦清川26 分钟前
C++多态~~的两个特殊情况
开发语言·c++
Purepisces33 分钟前
深度学习笔记: 最详尽解释预测系统的分类指标(精确率、召回率和 F1 值)
人工智能·笔记·python·深度学习·机器学习·分类
Star Patrick43 分钟前
算法训练(leetcode)第二十二天 | 491. 非递减子序列、全排列、47. 全排列 II
c++·算法·leetcode
可惜我是水瓶座__43 分钟前
【LeetCode】分发糖果
算法·leetcode·职场和发展
jiayoushijie-泽宣1 小时前
深入浅出3D感知中的优化与基于学习的技术 (第二章) 原创教程
人工智能·学习·算法·机器学习·3d·机器人
天黑我就困1 小时前
C语言使用先序遍历创建二叉树
c语言·数据结构·算法
LNTON羚通1 小时前
视频监控业务平台LntonCVS国标视频综合管理平台功能及技术优势
大数据·网络·人工智能·算法·音视频