JAVA容器-模拟LinkedList实现(双链表)

Posted 码农皮邱

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JAVA容器-模拟LinkedList实现(双链表)相关的知识,希望对你有一定的参考价值。

概述

  LinkedList实质上就是双向链表的拓展的实现,我们将关注一下问题。LinkedList

  1、双向链表怎么来实现插入、删除、查询?

  2、利用二分法提高查询效率。

  3、不同步,线程不安全,需要使用Collections.synchronizedList()达到线程安全。

  4、简单说,LinkedList就是数据结构中关于数据操作吗?

模拟实现

1、实现总体图(初始状态)

2、论述双链表的实现思想

  双向链表也叫双链表,是链表的一种,它的每个数据结点中都有两个指针,分别指向直接后继和直接前驱。所以,从双向链表中的任意一个结点开始,都可以很方便地访问它的前驱结点和后继结点。查询即从第一个节点,不断指向下一节点以便获得自己目标节点。删除、插入同理,最后修改目标节点的前后关系即可,就不多论述了。

3、采用二分法,向下遍历节点

 1  public Node node(int index){
 2         Node temp=first;
 3     //采用二分法遍历节点
 4         if(index<size<<1){
 5             for(int i=0;i<index;i++){
 6                 temp=temp.getNext();
 7             }
 8         }else{
 9             for(int i=size-1;i>index;i--){
10                 temp=temp.getPrevious();
11             }
12         }
13         return temp;
14     }

4、查询

1 public Object get(int index){
2         checkRange(index);
3         Node temp=null;
4         if(null!=first){
5             temp=node(index);
6         }
7         return temp.getObj();
8  }

5、插入一个元素(头部插入、尾部插入、中间插入)

public void add(int index,Object obj){
        checkRange(index);
        //移动指针,指向索引位置的节点
        Node temp=node(index);
        //从中间任任意一个位置插入
        if(first!=null){
            //创建一个新节点
            Node n=new Node();
            //修改当前节点的前后节点
            Node before=temp.getPrevious();
            n.setPrevious(before);
            n.setNext(temp);
            n.setObj(obj);
            before.setNext(n);
            temp.setPrevious(n);
        }
    }
</span><span style="color: #0000ff;">public</span> <span style="color: #0000ff;">void</span><span style="color: #000000;"> add(Object obj){
    Node n</span>=<span style="color: #0000ff;">new</span><span style="color: #000000;"> Node();
    </span><span style="color: #008000;">//</span><span style="color: #008000;">如果队头为空从队头插入</span>
    <span style="color: #0000ff;">if</span>(first==<span style="color: #0000ff;">null</span><span style="color: #000000;">){
        </span><span style="color: #008000;">//</span><span style="color: #008000;">初始状态:头尾指针指向第一个节点</span>

n.setObj(obj);
n.setPrevious(
null);
n.setNext(
null);
first
=n;
last
=n;
}
else{
//从队尾部插入
n.setObj(obj);
n.setPrevious(last);
n.setNext(
null);
//上一个实现的next指向下一个节点
last.setNext(n);
last
=n;
}
size
++;
}

 6、删除

 1 public void remove(int index){
 2     checkRange(index);
 3      if (null!=first){
 4         //遍历直到目标节点
 5         Node temp=node(index);
 6          Node befor=temp.getPrevious();
 7          Node after=temp.getNext();
 8          after.setPrevious(befor);
 9          befor.setNext(after);
10           size--;
11       }
12 }

7、源于揭秘LinkedList的核心部分,就没有赘述所有实现的方法。

以上是关于JAVA容器-模拟LinkedList实现(双链表)的主要内容,如果未能解决你的问题,请参考以下文章

第二节2:Java集合框架之LinkedList

Java源码阅读(不断补充)

Java集合002 --- LinkedList源码解析

创建链表LinkedList

『数据结构与算法』链表(单链表双链表环形链表):原理与Java实现

数据结构 Java 版玩转链表双链表