单链表和双链表

单链表
     单链表只有一个指向下一结点的指针,也就是只能next
双链表
     双链表除了有一个指向下一结点的指针外,还有一个指向前一结点的指针,可以通过prev()快速找到前一结点,顾名思义,单链表只能单向读取

为什么市场上单链表的使用多余双链表呢?

    从存储结构来看,每个双链表的节点要比单链表的节点多一个指针,而长度为n*length(这个指针的length在32位系统中是4个字节,在64位系统中是 8个字节)的空间,这在一些追求效率不高的应用下并不适应,因为它占用空间大于单链表所占用的空间;这时设计者就会采用以时间换取空间的做法,这是一种工程总体上的衡量标准。

链表的优点:

  • 插入删除速度快(因为有next指针指向其下一个节点,通过改变指针的指向可以方便的增加删除元素)
  • 内存利用率高,不会浪费内存(可以使用内存中细小的不连续空间(大于node节点的大小),并且在需要空间的时候才创建空间)
  • 大小没有固定,拓展很灵活。

链表的缺点:

  • 不能随机查找,必须从第一个开始遍历,查找效率低

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值