任意位置 单链表 回归

单链表的操作 主要就是 地址 指针的指向的改变 主要是弄懂 简单的几个重要的节点

主要 1 在 指定位置之前插入 数据

2 在 指定位置之后插入 数据

3 删除 指定位置 的数据

4 删除 指定位置之后 的数据

5 销毁 整个链表

第 1 在 指定位置之前插入 数据

首先 可能 需要修改头指针的指向所以 需要传一个二级指针的地址

其次需要知道该位置的前一个节点的地址 以及插入的数据

逐行重点理解的是 首先最基本的断言 判空 create 一个新的节点

其次 分类 为啥呢?画图 当且仅有一个有效节点时,prev的下个节点一直是空 永远不等于 pos循环不会结束 避免这种情况的发生所以选择 分支去隔离 当是这种情况的时候就直接调用 头插的函数就 ok

另一种情况 就是普遍的案例 当我们 在 pos 这个位置之前 插入的时候 需要先找到 prev的位置

用循环去找 就是 主要利用循环的结束条件来看 当prev->next == pos时 循环结束 刚好停在 pos之前的那个位置

其次重要注意的是 新节点 指向前后顺序问题 首先 是 1 然后 2

因为如果先是 2 则会找不到 pos这个节点 只有 prve 指向 新节点 而新节点找不到 pos

因为 prev的下个节点已经被你指向了 新节点 失去了关系 找不到了 就 是分手了 别找我i

第二种 2 在 指定位置之后插入 数据

相比于 在指定位置之前来说 不会修改头节点

而且既然有指定的位置 自然排除了 空链表的情况

图例 很清楚 下一个

第三种 删除 指定位置 的数据

认识删除 不是直接删 而是通过 别的途径做到从原链表中看不到而已

就像顺序表的删除 只是对下标的修改 限制 使得其是否在边界里而已

链表 而是通过指针的指向 让元素跳过 该节点做到删除的目的

和 插入一样 当有且只有一个节点时 直接 调用 原有的删除函数即可

记得这里执行顺序是 从右至左 别忘记释放并置为空该删除的位置

4 删除 指定位置之后 的数据

逐行解读 主要是删除后一个节点所以断言不能为空

5 销毁 整个链表

依旧 while循环 主要就是 先将下个节点的指针存起来 再把当前的节点释放

如此往复 直至 最后 指向null循环结束 别忘记将头节点置为空 因为空间全部被释放了

相关推荐
Dovis(誓平步青云)4 分钟前
《QT学习第四篇:常见事件与UDP、TCP、文件系统、(锁、信号量、条件变量》
c语言·开发语言·汇编·qt
.千余13 小时前
【C++】C++类与对象2:C++构造函数、运算符重载与流输入输出全面解析
c语言·开发语言·前端·c++·经验分享
QiLinkOS15 小时前
【用呼吸重构创造价值关系——QiLink生态】
c语言·数据结构·c++·人工智能·单片机·嵌入式硬件·算法
水无痕simon15 小时前
8 判断,分支,循环语句
c语言
朔北之忘 Clancy15 小时前
2026 年 3 月青少年软编等考 C 语言二级真题解析
c语言·开发语言·c++·学习·青少年编程·题解·考级
万法若空15 小时前
Libevent C语言开发完全教程:从入门到实战
c语言·网络
kkeeper~16 小时前
0基础C语言积跬步之自定义类型结构体
c语言·开发语言
小何code18 小时前
C语言【初阶】第1节,初识C语言
c语言·开发语言
莫陌尛.18 小时前
Fuzzy C-Mean Clustering (FCM)
c语言·开发语言
飞天狗11120 小时前
2025第十六届蓝桥杯c/c++B组国赛题解
c语言·c++·算法·蓝桥杯