[集合]LinkedList

LinkedList实现了 List (列表)& Deque(双向队列) 接口, 预习一下java集合家族

 

 

 

 

1. 添加操作

    public boolean add(E e) {
        linkLast(e);
        return true;
    }

    void linkLast(E e) {
        final Node<E> l = last;
        final Node<E> newNode = new Node<>(l, e, null);
        last = newNode;
        if (l == null)
            first = newNode;
        else
            l.next = newNode;
        size++;
        modCount++;
    }
添加操作只需要添加新节点,加入双向链表
2.Get操作
    public E get(int index) {
        checkElementIndex(index);
        return node(index).item;
    }
    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;
        }
    }

 获取操作会先判断是在队列的左侧还是右侧,然后依次遍历 

posted @ 2019-09-18 15:19  安琪拉的博客(公众号)  阅读(176)  评论(0编辑  收藏  举报