任意位置 单链表 回归

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

主要 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循环结束 别忘记将头节点置为空 因为空间全部被释放了

相关推荐
LDR0066 天前
Type-C 快充全面升级!LDR6601 赋能个人护理便携电机,重塑剃须刀 / 理发器新体验
c语言·开发语言
Luminous.6 天前
C语言--day30
c语言·开发语言
玖玥拾6 天前
C/C++ 数据结构(七)栈、容器适配器
c语言·数据结构·c++··容器适配器
謓泽6 天前
C语言不是语法,是通往机器的地图。
c语言·开发语言
不会C语言的男孩6 天前
Linux 系统编程 · 第 8 章:进程基础
linux·c语言
2601_951643886 天前
C语言长文整理,关键字和数据类型
c语言·数据类型·关键字·嵌入式开发·格式化输出
m0_547486666 天前
《C#语言程序设计与实践》 全套PPT课件
c语言·c#·c语言程序设计
✎ ﹏梦醒͜ღ҉繁华落℘6 天前
编程基础 --高内聚,低耦合
c语言·单片机
疯狂成瘾者6 天前
Java 集合 LinkedList 详解:链表结构、常用方法和队列使用
java·开发语言·链表
QK_006 天前
C语言 static 关键字三大作用
c语言·开发语言