【线性表】顺序表和链表的比较

比较

如前面所说,数据结构是存储和组织数据的一种方式,以便于对数据进行访问和修改。

没有哪一种数据结构可以适用于所有的用途和目的。下面看看,在实际应用中,顺序表和链表应该选择哪个。


基于空间的考虑:

    内存分配问题:顺序表属于静态分配,必须实现知道所需的内存空间大小。但是,如果分配内存过大,将造成空间的浪费,如果分配过小,将内存空间溢出机会变大。所以,如果难以估计空间内存大小,应该使用链表

    内存效率问题:顺序表各个元素之间有默认的数据关系(相邻),而链表必须要增加指针域来表达各元素之间的关系,所以,从内存利用率上考虑,如果内存大小事先比较易于估计,应该使用顺序表;


基于时间的考虑:

    顺序表是一种随即存储结构,即只要知道了位置,就可以直接访问;但是,它的一个很大的缺点是,如果要进行插入、删除等操作,将必须移动一半的结点(平均),而在链表中进行插入、删除等操作,只需要修改指针;所以,对于频繁进行插入、删除的线性表,应该采用链表。不过,话又说回来,如果要访问表中的结点,链表也是需要查询一半的结点(平均),而顺序表只需要O(1)的时间,所以,如果线性表很少做插入、删除操作,应该采用顺序表

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值