3.8.2单链表的删除

简介:         现在我们再来看单链表的删除。设存储元素ai的结点为q,要实现将结点q删除单链表的操作,其实就是将它的前继结点的指针绕过,指向它的后继结点即可(如图3-8-5所示)。

        现在我们再来看单链表的删除。设存储元素ai的结点为q,要实现将结点q删除单链表的操作,其实就是将它的前继结点的指针绕过,指向它的后继结点即可(如图3-8-5所示)。
        我们所要做的,只是实际上就是一步,p->next=p->next->next,用q来取代p->next,即是
q=p->next; p->next=q->next;

        解读这两句代码,也就是说让p的后继的后继结点改成p的后继结点。有点拗口呀,那我再打个形象的比方。本来是爸爸左牵着妈妈的手,右牵着宝宝的手在马路边散步。突然迎面走来一美女,爸爸一下子看呆了,此情景被妈妈逮个正着。于是她生气地甩开牵着的爸爸的手,绕过他,扯开父子俩,拉起宝宝的左手就快步朝前走去。此时妈妈是p结点,妈妈的后继是爸爸p->next,也可以叫q结点,妈妈的后继的后继是儿子p->next->next,即q->next。当妈妈去牵儿子的手时,这个爸爸就已经与母子俩没有牵手联系了(如图3-8-6所示)。

        单链表第i个数据删除结点的算法思路:
        1. 声明一结点p指向链表第一个结点,初始化j从1开始;
        2. 当j<i时,就遍历链表,让p的指针向后移动,不断指向下一个结点,j累加1;
        3. 若到链表末尾p为空,则说明第i个元素不存在;
        4. 否则查找成功,将欲删除的结点p->next赋值给q;
        5. 单链表的删除标准语句 p->next=q->next;
        6. 将q结点中的数据赋值给e,作为返回;
        7. 释放q结点;
        8. 返回成功。

        实现代码算法如下:

复制代码
/* 初始条件:顺序线性表L已存在,1≤i≤ListLength(L)  */
/* 操作结果:删除L的第i个数据元素,并用e返回其值,L的长度减1 */
Status ListDelete(LinkList 
* L,  int  i, ElemType  * e) 

     
int  j;
      LinkList p, q;
      p 
=   * L;
      j 
=   1 ;
      
while  (p -> next  &&  j  <  i)  /* 遍历寻找第i个元素 */
      {
             p 
=  p -> next;
             
++ j;
      }
      
if  ( ! (p -> next)  ||  j  >  i) 
             
return  ERROR;         /* 第i个元素不存在 */
      q 
=  p -> next;
      p
-> next  =  q -> next;   /* 将q的后继赋值给p的后继 */
      
* =  q -> data;           /* 将q结点中的数据给e */
      free(q);                
/* 让系统回收此结点,释放内存 */
      
return  OK;
}
复制代码

 

        这段算法代码里,我们又用到了另一个C语言的标准函数free。它的作用就是让系统回收一个Node结点,释放内存。
        分析一下刚才我们讲解的单链表插入和删除算法,我们发现,它们其实都是由两部分组成:第一部分就是遍历查找第i个元素;第二部分就是插入和删除元素。从整个算法来说,我们很容易推导出:它们的时间复杂度都是O(n)。如果在我们不知道第i个元素的指针位置,单链表数据结构在插入和删除操作上,与线性表的顺序存储结构是没有太大优势的。但如果,我们希望从第i个位置,插入10个元素,对于顺序存储结构意味着,每一次插入都需要移动n-i个元素,每次都是O(n)。而单链表,我们只需要在第一次时,找到第i个位置的指针,此时为O(n),接下来只是简单地通过赋值移动指针而已,时间复杂度都是O(1)。显然,对于插入或删除数据越频繁的操作,单链表的效率优势就越是明显。

目录
相关文章
|
7月前
|
传感器 人工智能 安全
物联网
万物互联,智启未来。物联网通过连接人、物、环境,重塑生活、城市与产业。从智能家居到智慧城市,从工业互联网到精准农业,数据驱动智能化变革。融合AI、5G等技术,构建高效、安全、可持续的智能世界,开启人类社会新篇章。(238字)
|
机器学习/深度学习 数据可视化 算法
经典时间序列分析概述:技术、应用和模型
时间序列数据按时间顺序收集,具有时间维度的重要性,需专门技术和模型进行分析预测。其应用广泛,涵盖经济预测、风险管理、天气预报、气候建模、流行病学、患者监测、需求预测、客户行为分析及预测性维护等领域。时间序列特征包括趋势、季节性和周期性模式。自相关和偏自相关用于衡量数据点间关系,白噪声表示无自相关的时间序列。平稳性指统计特性随时间保持一致,对建模至关重要。常见模型包括ARMA、ARIMA、SARIMA、ARCH和GARCH,用于捕捉复杂动态并预测未来模式。选择合适模型和确定顺序对准确预测至关重要。掌握这些基础知识不仅增强对复杂模型的理解,还能确保预测方法的稳健性和可靠性。
3481 2
经典时间序列分析概述:技术、应用和模型
|
运维 监控 供应链
你真的了解物联网卡吗
"你真的了解物联网卡吗?" 这个问题触及了物联网(IoT)领域中的一个关键组成部分——物联网卡。为了深入回答这个问题,我们可以从以下几个方面进行解析和操作:
|
存储 开发工具 git
Git的基本使用方法
Git的基本使用方法
|
存储 开发工具 Android开发
Android 11 上的文件读写权限(MANAGE_EXTERNAL_STORAGE)
Android 11 上的文件读写权限(MANAGE_EXTERNAL_STORAGE)
3683 0
Android 11 上的文件读写权限(MANAGE_EXTERNAL_STORAGE)
|
移动开发 缓存 HTML5
是时候学习/推广一波可选链(Optional chaining)和空值合并(Nullish coalescing )了
最近工作中发现团队有些同学不太了解 Optional chaining 和 Nullish coalescing 两个新的操作符,正好推广一波。
是时候学习/推广一波可选链(Optional chaining)和空值合并(Nullish coalescing )了
|
存储 编译器 程序员
[C语言] 初始字符串 & 转义字符与注释
注:字符串的结束标志是一个反斜杠(\0)的转义字符。在计算机字符串长度的时候反斜杠(\0)是不算做字符串的内容当中的。 说的简单一点的话:字符串就是一串字符,双引号括起
375 0
[C语言] 初始字符串 & 转义字符与注释
|
算法 数据安全/隐私保护
|
16天前
|
人工智能 数据可视化 安全
王炸组合!阿里云 OpenClaw X 飞书 CLI,开启 Agent 基建狂潮!(附带免费使用6个月服务器)
本文详解如何用阿里云Lighthouse一键部署OpenClaw,结合飞书CLI等工具,让AI真正“动手”——自动群发、生成科研日报、整理知识库。核心理念:未来软件应为AI而生,CLI即AI的“手脚”,实现高效、安全、可控的智能自动化。
34816 42
王炸组合!阿里云 OpenClaw X 飞书 CLI,开启 Agent 基建狂潮!(附带免费使用6个月服务器)

热门文章

最新文章

下一篇
开通oss服务