(java实现)双向循环链表
2020-12-13 15:46
标签:基本操作 ref lock 数据 内容 else 复杂度 缩小 概念 在了解双向循环链表之前,如果对链表还没有一个清晰的概念,建议你看看单链表和单向循环链表,这有利于你更好的理解下面的内容。(废话有点多[逃] 相比单链表,双向循环链表是一个更加复杂的结构。因为双向循环链表的节点不仅包含指向下一个节点的指针(next),还包含指向前一个节点的指针(prev)。 双向循环链表的基本操作有:增(add),删(remove),改(set),查(find),插(insert)等。在这里我们只讲解remove,insert和getNode操作,其他实现可看下方源码。 由于双向链表有两个可见的节点(head和end),因此双向循环链表获取节点的操作和单链表有所不同。 双链表的设计应用了算法设计的“空间换时间”思想,通过消耗更多的空间来缩小操作的时间复杂度。 (java实现)双向循环链表 标签:基本操作 ref lock 数据 内容 else 复杂度 缩小 概念 原文地址:https://www.cnblogs.com/sang-bit/p/11614232.html什么是双向循环链表
基本操作
获取节点
删除元素
插入元素
双向循环链表的优劣
优势
劣势
源码实现
public class Node {
public Anytype data;//数据
public Node prev;//前一个节点
public Node next;//后一个节点
public Node(Anytype data,Node prev,Node next){
this.data=data;
this.prev=prev;
this.next=next;
}
}
----------------------------------------------
public class DoubleLink {
Node head;//头指针
Node end;//尾节点
int size;//记录链表长度
//初始化链表
public void initlist(){
end=new Node(null,null,null);
head=new Node(null,null,end);
end.prev=head;
end.next=head;
size=0;
}
//获取长度
public int length(){
return size;
}
//获取节点
public Node getNode(int index){
Node n;
if(index>=size/2){
n=end;
for(int i=length();i>index;i--){
n=n.prev;
}
return n;
}
else{
n=head;
for(int i=0;i(a,getNode(size-1),end);
renode.prev.next=renode;
renode.next.prev=renode;
size++;
}
//插入元素
public void insert(int i,AnyType a){
Node n=getNode(i);
Node renode=new Node(a,n.prev,n);
n.prev.next=renode;
n.prev=renode;
size++;
}
//删除元素
public AnyType remove(int i){
Node n=getNode(i);
AnyType data=n.data;
n.prev.next=n.next;
n.next.prev=n.prev;
size--;
return data;
}
//获取i位置的数据
public AnyType get(int i){
return getNode(i).data;
}
//为i位置元素重新赋值
public AnyType set(int i,AnyType a){
Node n=getNode(i);
AnyType old=n.data;
n.data=a;
return old;
}
//清空链表
public void clear(){
initlist();
}
public void print(){
for(int i=0;i