数据结构 第4讲 数组、单链表和双链表

数组:
数组静态分配内存,在内存中连续
存储0,10,20,30,40,的数组的示意图如下:

image

数组的优点:
1.使用方便,查询效率、
2.随机访问性强(通过下标进行快速定位)
数组的缺点:
1.插入和删除效率低(插入和删除需要移动数据)
2.可能浪费内存(因为是连续的,所以每次申请数组之前必须规定数组的大小,如果大小不合理,则可能会浪费内存)
3.内存空间要求高,必须有足够的连续内存空间。
4.数组大小固定,不能动态拓展

链表是一系列的存储数据元素的单元通过指针串接起来形成的,因此
链表的优点:
1.链表实现数据元素储存的顺序储存,是连续的
2.大小没有固定,拓展很灵活
3.不需要初始化容量,可以任意加减元素
链表的缺点:
1.不能随机查找,必须从第一个开始遍历,查找效率低
2.因为含有大量的指针域,占用空间较大

image

image
单链表:
链表是动态分配内存在内存中不连续,单链表只有一个向下的指针,指向下一个节点,单链表的定位时间复杂度是O(n),插入删除的时间复杂度是O(1)
image

image
双链表:
链表是动态分配内容在内存中不连续,单双链表一致,双链表有两个指针header,next ,header指向上一个节点,next指向下一个节点

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值