DS-浅谈顺序表和链表的区别

如果学过数据结构,大家都知道不论是顺序表还是链表其实都属于是线性表的一种,而顺序表和链表都是非常常见的线性表,所以在谈顺序表和链表之前简单说一下线性表:

线性表在逻辑上是线性结构,也就说是连续的一条直线。但是在物理结构上并不一定是连续的,线性表在物理存储结构上存储时,通常以数组和链式结构的形式存储。
在这里插入图片描述
1. 顺序表
原理:
顺序表是用一段物理地址连续的存储单元依次存储数据元素的线性结构,一般情况下采用数组存储,其结构类似上图中的数组结构。
优点:
(1)空间的利用率较高,存储空间连续。
(2)支持通过下标随机访问,存取效率较高,时间复杂度为O(1)。
缺点:
(1)插入和删除的效率较低,需要遍历整个数组,时间复杂度为O(n)。
(2)容量(长度)固定,如果需要增容,代价较大,而且一般增容的大小为原容量的二倍,必然存在空间的浪费。
时间性能:
查找的时间复杂度为O(1),插入和删除的时间复杂度为O(n)。

2.链表
原理:
链表是一种物理存储结构上非连续、非顺序的存储结构,数据元素的逻辑顺序是通过链表中的指针链接次序实现的 ,其结构类似于上图中的链式结构。
优点:
(1)任意位置插入和删除的效率高,速度快,时间复杂度为O(1)。
(2)没有空间限制,不存在扩容问题,插入一个元素开辟一个空间。
缺点:
(1)以节点为单位存储,不支持随机访问,时间复杂度为O(n)。
(2)占用额外的空间以存储指针(浪费空间,不连续存放,malloc开辟,空间碎片多) 。
时间性能:
查找的时间复杂度为O(n),插入和删除的时间复杂度为O(1)。

对于这两种存储结构,要根据不同的需求来选择不同的存储方式。
比如:

  • 如果频繁的查找却很少使用插入和删除操作可以用顺序表存储,堆排序,二分查找适宜用顺序表
  • 如果频繁的插入和删除操作,很少的查询就可以使用链表存储
  • 顺序表适宜于做查找这样的静态操作;链表适宜于做插入、删除这样的动态操作
  • 若线性表长度变化不大,如果事先知道线性表的大致长度,比如一年12月,一周就是星期一至星期日共七天,且其主要操作是查找,则采用顺序表
  • 若线性表长度变化较大或根本不知道多大时,且其主要操作是插入、删除,则采用链表,这样可以不需要考虑存储空间的大小问题
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值