单链表模拟(也是邻接表的前置)
创始人
2024-06-02 14:53:25
0

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

  1. 向链表头插入一个数;

  1. 删除第 k� 个插入的数后面的数;

  1. 在第 k� 个插入的数后插入一个数。

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

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

输入格式

第一行包含整数 M�,表示操作次数。

接下来 M� 行,每行包含一个操作命令,操作命令可能为以下几种:

  1. H x,表示向链表头插入一个数 x�。

  1. D k,表示删除第 k� 个插入的数后面的数(当 k� 为 00 时,表示删除头结点)。

  1. I k x,表示在第 k� 个插入的数后面插入一个数 x�(此操作中 k� 均大于 00)。

输出格式

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

数据范围

1≤M≤1000001≤�≤100000

所有操作保证合法。

#include 
#include 
#include 
#include 
#include 
#include  
#include 
#include 
#include 
#include 
#include 
using namespace std;
typedef long long ll;
typedef pair PII;
const ll maxx = 1e9;
int n, m, T;
const int N = 1e5 + 10;
const int INF = 0x3f3f3f3f;
const double pi = acos(-1.0);
int dx[4] = { 0 , 1 , -1 , 0 }, dy[4] = { 1 , 0 , 0 , -1 };
int h[N], e[N], ne[N], head, idx;
void in()
{head = -1;//在没有元素的时候指向-1,在有元素的情况下指向第一个元素的指针idx = 0;//在一开始作为链表的下标,在链表的各种插入 , 删除的时候作为辅助工作,并且是}
void into(int x)//插入
{e[idx] = x;//将值放入ne[idx] = head;head现在作为指针指向空节点 , 现在ne[idx] = headhead = idx;idx++;//所有的操作进行后idx都得++,idx指向的是当前地址//所有的访问是靠ne[]来访问的,包括遍历链表也是靠ne[],这样不管下标如何混乱都可以继续操作
}
void add(int k, int x)//将x插入到k点之后
{e[idx] = x;//先将元素插入ne[idx] = ne[k];//让元素x配套指针,指向它要站位的元素下一位ne[k] = idx;//让原来的指针指向自己idx++;//将idx向后挪
}
void remove(int k)
{ne[k] = ne[ne[k]];//让k的指针指向下一个,k下一个的下一人,那中间那位就被挤掉了//这里idx
}
void solve()
{cin >> n;in();//初始化for (int i = 0; i < n; i++){char s;cin >> s;if (s == 'H'){int x;cin >> x;into(x);//进行插入}if (s == 'D'){int k;cin >> k;if (k == 0){head = ne[head];//删除头结点}else{remove(k - 1);}}if (s == 'I'){int k, x;cin >> k >> x;add(k - 1, x);}}for (int i = head; i != -1; i = ne[i]){cout << e[i] << " ";}cout << endl;
}
int main()
{ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);//cin >> T;//while (T--)//{solve();//}return 0;
}

相关内容

热门资讯

将安卓系统数据导入ios系统,... 你是不是也有过这样的经历:手机里存满了珍贵的照片、联系人、应用数据,突然有一天,你决定换一台iPho...
雷霆战机 安卓最低系统,系统要... 你有没有听说过这款超级酷炫的飞行游戏——雷霆战机?没错,就是那个让你一上手就停不下来的刺激游戏!今天...
电脑独立安装安卓系统,探索电脑... 电脑独立安装安卓系统:探索未来的可能性在当今这个数字化时代,电脑已经不仅仅是一个用来打字的工具,它更...
树莓派虚拟安卓系统,打造便携式... 你有没有想过,用树莓派来运行安卓系统?听起来是不是有点酷炫?想象一个迷你的小树莓派,竟然能变身成为一...
安卓系统如何安装tk,安卓系统... 你有没有想过,你的安卓手机里装个tk,生活是不是能变得更有趣呢?别急,别急,我来给你详细说说怎么操作...
安卓计步数系统,健康生活新伙伴 你有没有发现,每天手机里那个默默无闻的安卓计步数系统,竟然悄悄地记录了你走过的每一步?今天,就让我带...
安卓原生系统真的好吗,究竟是否... 你有没有想过,安卓原生系统到底是不是那个传说中的“好”?咱们今天就来聊聊这个话题,看看这个系统到底有...
安卓2.3系统开机画面,复古与... 亲爱的读者,你是否还记得那些充满怀旧情怀的安卓2.3系统开机画面?那个曾经陪伴我们度过无数时光的小图...
哪个安卓管理系统好,安卓管理系... 你有没有想过,手机里那么多应用,管理起来是不是有点头疼?别急,今天就来给你揭秘哪个安卓管理系统好,让...
安卓系统取消流量监控,告别流量... 你知道吗?最近安卓系统来了一次大动作,取消了对流量的监控!这可真是让人眼前一亮的消息呢。想象以前每次...
安卓导航如何备份系统,安卓导航... 你有没有想过,如果你的安卓导航系统突然崩溃了,你会怎么办?别急,今天就来给你支个招,教你如何轻松备份...
小米安卓4.0系统下载,深度解... 你有没有想过,你的小米手机是不是也能来个“大变身”?没错,就是升级到安卓4.0系统!想象你的手机瞬间...
自动鉴别平板安卓系统,自动鉴别... 你有没有想过,你的平板电脑里那些安卓系统,其实都是经过一番“智慧”的筛选和鉴别才来到你面前的呢?没错...
bose能连安卓系统,开启无线... 你有没有想过,家里的音响设备也能跟上科技潮流,和你的安卓手机无缝连接呢?没错,今天就要来聊聊这个神奇...
安卓x是什么系统,探索新一代智... 你有没有听说最近安卓界又出了个新花样——安卓X系统?没错,就是那个我们平时手机里常用的安卓系统,这次...
安卓系统怎么提升网速,五大技巧... 你是不是也和我一样,在使用安卓手机时,总是觉得网速不够快,有时候刷个网页都慢得让人抓狂?别急,今天就...
机车安卓系统重装,轻松恢复系统... 你那台机车安卓系统是不是突然间卡壳了,运行速度慢得像蜗牛爬?别急,今天就来给你详细说说怎么给机车安卓...
华为手机更改安卓系统,探索安卓... 你知道吗?最近华为手机界可是掀起了一阵不小的波澜呢!没错,就是那个我们熟悉的华为,竟然悄悄地更改了安...
安卓系统低版微信,揭秘微信新版... 你有没有发现,有时候手机里的微信版本有点儿“老气横秋”呢?别急,今天就来聊聊这个让人有点头疼的安卓系...
安卓系统安装apple pay... 你有没有想过,即使你的手机是安卓系统,也能享受到Apple Pay的便捷支付体验呢?没错,就是那个曾...