ArrayList和LinkedList时间、空间复杂度对比

时间复杂度

查询

对于存储相同列表的ArrayList和LinkedList来说,ArrayList内部的实现是基于对象数组,而LinkedList是基于指针链表,ArrayList的查询是基于二分查找算法,LinkedList是不支持快速随机访问。所以,查询,ArrayList的速度是快鱼LinkedList的

插入和删除

当有元素插入和删除ArrayList时,该元素其后的元素都会进行移动,这就会造成移动会复制元素上的大量开销。相反的是,将元素插入或删除LinkedList只是简单的将该元素前后元素的next和previous节点进行修改即可

空间复杂度

LinkedList内部类是一个元素对象和上下节点,而ArrayList扩容是根据公式:新容量 = (旧容量*3 )/2 + 1,也就是每次容量大约会增加50%,如果用不完这50%,就会浪费很多空间。
所以,ArrayList在空间浪费上是大于LinkedList的。

总结

ArrayList是线性表(数组)
get()直接读取几个下标,时间复杂度O(1)
add(index,E)添加元素,其后元素需要移动,复杂度O(n)
remove()删除元素,其后元素逐个移动,复杂度O(n)

LinkedList是链表
get()获取第几个元素,依次遍历,复杂度O(n)
add(index,E)添加元素,修改前后元素的next和previous节点,复杂度O(1)
remove()删除元素,直接指向指针操作,复杂度O(1)

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值