什么是双向循环链表
在了解双向循环链表之前,如果对链表还没有一个清晰的概念,建议你看看单链表和单向循环链表,这有利于你更好的理解下面的内容。(废话有点多[逃]
相比单链表,双向循环链表是一个更加复杂的结构。因为双向循环链表的节点不仅包含指向下一个节点的指针(next),还包含指向前一个节点的指针(prev)。
![3cfb2159c2188132acb06b838a76be86.png](https://img-blog.csdnimg.cn/img_convert/3cfb2159c2188132acb06b838a76be86.png)
在双向循环链表中,可见的不只有头指针head,还有尾节点end。这是和单链表的区别。
双向循环链表的头指针head的前一个节点指向end,尾节点end的后一个节点指向head。
基本操作
双向循环链表的基本操作有:增(add),删(remove),改(set),查(find),插(insert)等。在这里我们只讲解remove,insert和getNode操作,其他实现可看下方源码。
获取节点
由于双向链表有两个可见的节点(head和end),因此双向循环链表获取节点的操作和单链表有所不同。
把需要获取的节点序号和链表长度/2比较
若小于,说明节点是偏前的,因此从head开始一路next下去
若大于,说明节点是偏后的,因此从end开始一路prev上去
这样的设计能使getNode操作的时间复杂度缩短为O(logN)