链表(一)——无头单向非循环链表实现

一、初始链表

  • 链表属于线性结构,包含一个元素序列,序列中的每一个元素都可以引用序列中下一个元素。
  • 链表在物理空间上是非连续的,每一个元素之间存在间隙,在逻辑上,是连续的,每一个序列中的元素与下一个元素形成链式结构,跟轨道上的火车一样,整体形成一个有序序列。
  • 链表通过一个个结点组成,每一个结点里包括数据域和储存下一个结点地址的next,有时候存在虚拟结点,就是不存在数据域,只有next,它的作用是将头部和其他位置相统一,方便后续的添加、插入、删除等操作。
    在这里插入图片描述
  • 现实中的结点一般都是在堆上申请空间

顺序表与链表的区别

  • 顺序表在物理空间上是连续的,其底层逻辑由数据搭建,链表序列的每一个元素是通过结点上的next来实现逻辑上的连续
  • 链表不存在扩容问题,顺序表的数组是指定的大小,当指定的大小已经满了,就会扩大容量,系统一般会以1.5倍扩容,如果没有充分利用就会浪费空间,造成内存碎片
  • 链表插入和删除,时间复杂度与顺序表一样,总体都是O(n)级别,但是链表的效率比顺序表快很多,因为链表插入和删除不用挪数据,只用读数据,而顺序表插入一个数据和删除一个数据,后续序列的元素都需要跟着向前或者向后移动。不过尾插尾删操作顺序表效率高。
  • 顺序表存在下标,支
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值