Java集合——LinkedList

一、概述

以双向链表实现。链表无容量限制,但是双向链表本身使用了更多的空间,也需要额外的链表指针操作。

按照下标访问数据——get(i)/set(i,e),要遍历链表指针移动到位(如果i>数组大小的一半,会从末尾移起)。

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

LinkedList与ArrayList不同的是,他是基于链表实现的。

LinkedList<String> list = new LinkedList<String>();
list.add("张三:1");
list.add("李四:2");
list.add("王二麻子:3");

二、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)。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值