数据结构对比

一、数组

数组的优点

  1. 数组按索引查找,效率非常高。

数组的缺点

  1. 数组的创建通常需要申请一段连续的内存空间(一整块的内存),并且大小是固定的(大多数编程语言数组都是固定的),所以当前数组不能满足需求时,需要扩容。一般情况下是申请一个更大的数组,比如2倍,然后将原来数组中的元素复制过去。
  2. 数组开头或中间插入、删除数据的成本较高,需要大量元素的位移。
  3. 数组按内容查找,效率非常低。

总结:当频繁用下标访问时选择数组。

 

二、链表

链表的优点

  1. 链表中的元素在内存中不必是连续的空间,可充分利用计算机的内存,实现灵活的内存动态管理。
  2. 链表在创建时不必确定大小,并且大小可以无限延伸。
  3. 链表在插入和删除数据时,时间复杂度可达到O(1),相对数组效率高很多。

链表的缺点

  1. 无法通过下标直接访问元素,需从头开始访问,直到找到对应的元素

总结:当频繁插入和删除数据时选择链表

 

三、哈希表

哈希表的优点

  1. 插入、查询、删除的效率都非常高。

哈希表的缺点

  1. 空间利用率不高,底层使用的是数组,并且一些单元没有被利用
  2. 哈希表中的元素是无序的,不能按照固定的顺序来遍历元素
  3. 不能快速的找出哈希表中的最大值和最小值

 

四、树结构

树结构的优点:

可以表示一对多的关系。用在某些场景会比较方便,如文件的目录结构。

总结

树结构综合了上面的数据结构的优缺点,插入、删除、查询速度比数组、链表快,但比哈希表慢,但比哈希表空间利用率高,可查找最值

 

 

 

 

 

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值