Java-LinkedList各函数源码小结

复制一时爽,一直复制一直爽。

github地址:android_interview

虽然从github复制的,但自己再写一遍能更好的理解和加深记忆。此文章仅作为个人学习的知识点小结,不做任何其他用途。

1、概括

与ArrayList不同的是,LinkedList是基于链表实现的,并且是以双向链表实现的。链表无容量限制,但双向链表本身使用了更多空间,也需要额外的链表指针操作。

按下标访问元素—get(i)/set(i,e) 要悲剧的遍历链表将指针移动到位(如果i>数组大小的一半,会从末尾移起,否则从头开始移动)。

插入、删除元素时修改前后节点的指针即可,但还是要遍历部分链表的指针才能移动到下标所指的位置,只有在链表两头的操作—add(),addFirst(),removeLast()或用iterator()上的remove()能省掉指针的移动。

2、set和get函数

public E set(int index, E element) {
    checkElementIndex(index);
    Node<E> x = node(index);
    E oldVal = x.item;
    x.item = element;
    return oldVal;
}

public E get(int index) {
    checkElementIndex(index);
    return node(index).item;
}

这两个函数都调用了 node 函数,该函数会以O(n/2)的性能去获取一个节点,具体
实现如下所示:

Node<E> node(int index) {
    // assert isElementIndex(index);
    if (index < (size >> 1)) {
        Node<E> x = first;
        for (int i = 0; i < index; i++)
            x = x.next;
        return x;
    } else {
        Node<E> x = last;
        for (int i = size - 1; i > index; i--)
            x = x.prev;
        return x;
    }
}

就是判断index是在前半区间还是后半区间,如果在前半区间就从head搜索,而在
后半区间就从tail搜索。而不是一直从头到尾的搜索。如此设计,将节点访问的复杂
度由O(n)变为O(n/2)。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 前言 2. 实现 Singleton 3. 数组中重复的数字 4. 二维数组中的查找 5. 替换空格 6. 从尾到...
    Observer_____阅读 3,008评论 0 1
  • 本文是我自己在秋招复习时的读书笔记,整理的知识点,也是为了防止忘记,尊重劳动成果,转载注明出处哦!如果你也喜欢,那...
    波波波先森阅读 2,861评论 0 10
  • 处于青年的我们大概都阅读过《活着》,余华老师的《活着》是本好书,是一本触碰我们心灵的好书,它给予我们生命最本质的解...
    明水027贾小敏阅读 301评论 1 4
  • 操作事件简介 Monkey所执行的随机事件流中包含11大事件,分别是触摸事件、手势事件、二指缩放事件、轨迹事件、屏...
    柱柱007阅读 436评论 0 0
  • 当下,相亲大热,各种相亲节目层出不穷。有关相亲报道屡见不鲜。 未婚人士,工作之后,最常被问及的话题:有没有男朋友/...
    小铃铛语录阅读 240评论 0 1