【数据结构与算法】第3课—数据结构之单链表

1. 什么是链表

  • 链表是在逻辑结构上连续,而在物理结构上不一定连续的存储结构
  • 链表由一个一个的节点组成,并且这些节点是在堆上申请空间
  • 单链表的每个节点一般有两个变量,一个变量存储数据,另一个变量里面是下一个节点的地址,最后一个节点里面的那个变量存储的是空指针

在这里插入图片描述


在这里插入图片描述


2. 单链表

  • 从前往后,单向的一个链表

2.1 单链表的初始化和打印

  • 初始化

在这里插入图片描述


  • 打印单链表

在这里插入图片描述


2.2 单链表的尾插和头插

  • 尾插

在这里插入图片描述


在这里插入图片描述


在这里插入图片描述


  • 头插

在这里插入图片描述


在这里插入图片描述


在这里插入图片描述


2.3 单链表的尾删和头删

  • 尾删

在这里插入图片描述


在这里插入图片描述


在这里插入图片描述


在这里插入图片描述


  • 头删

在这里插入图片描述


在这里插入图片描述


在这里插入图片描述


2.4 单链表查找节点

在这里插入图片描述


在这里插入图片描述


2.5 单链表在指定位置之前/之后插入数据

  • 单链表在指定位置之前插入数据

在这里插入图片描述


在这里插入图片描述


  • 单链表在指定位置之后插入数据

在这里插入图片描述


在这里插入图片描述


在这里插入图片描述


2.6 单链表删除节点和删除pos之后的节点

  • 单链表删除节点pos

在这里插入图片描述


在这里插入图片描述


  • 单链表删除节点pos之后的节点

在这里插入图片描述


在这里插入图片描述


2.7 销毁链表

在这里插入图片描述


在这里插入图片描述


在这里插入图片描述


3. 单链表和顺序表对比

  • 顺序表头部/中间的插入删除的时间复杂度是O(N),而单链表头部的插入删除、删除指定位置之后的节点、指定位置之后插入数据的时间复杂度是O(1)
  • 而顺序表尾部插入/删除的时间复杂度是O(1),单链表尾部插入/删除、删除指定位置节点、指定位置之前插入节点的时间复杂度是O(N)
  • 顺序表需要增容,而且存在一定的空间浪费,而单链表每次只需要申请一个节点大小,不存在浪费空间的情况
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值