arraylist索引从几开始_Java 问答:用 ArrayList 还是 LinkedList

(给ImportNew加星标,提高Java技能)

编译:ImportNew/唐尤华

stackoverflow.com/questions/322715/when-to-use-linkedlist-over-arraylist-in-java

问题:

通常我会这么定义列表:

List names = new ArrayList<>();

names类型使用List接口,那么具体实现该如何选择。 

什么时候应该用LinkedList替代ArrayList,反之亦然?

总结:

大多数情况下,相比LinkedList更推荐使用ArrayList或ArrayDeque。如果不确定,可以直接选用ArrayList。

LinkedList和ArrayList是List接口的两种不同实现。LinkedList采用双向链表实现。ArrayList通过动态调整数组大小实现。

与标准链表和数组操作一样,不同的实现方法算法运行时也不同。

对于LinkedList

  • get(int index)复杂度为O(n)(平均步长n/4)

  • add(E element)复杂度为O(1)

  • add(int index, E element)复杂度为O(n)(平均步长n/4)。但是当index = 0时复杂度为O(1)的主要优点。

  • remove(int index)复杂度为O(n)(平均步长n/4)

  • Iterator.remove()复杂度为O(1)。的主要优点

  • ListIterator.add(E element)复杂度为O(1)。这是LinkedList的一个主要优点。

注意:许多操作平均需要n/4步长,最好的情况下(例如index= 0)步长为常数,最坏的情况下需要n/2步(列表中间)。

对于ArrayList

  • get(int i

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值