LinkedList
概述
以双向链表实现。链表无容量限制,但双向链表本身使用了更多空间,也需要额外的链表指针操作。
按下标访问元素,需要遍历链表(但不一定从头开始遍历链表)。
set和get函数
两个函数都调用了 node 函数,该函数会以O(n/2)的性能去获取一个节点。
判断index是在前半区间还是后半区间,如果在前半区间就从head搜索,而在后半区间就从tail搜索。而不是一直从头到尾的搜索。如此设计,将节点访问的复杂度由O(n)变为O(n/2)。
微信扫一扫
以双向链表实现。链表无容量限制,但双向链表本身使用了更多空间,也需要额外的链表指针操作。
按下标访问元素,需要遍历链表(但不一定从头开始遍历链表)。
两个函数都调用了 node 函数,该函数会以O(n/2)的性能去获取一个节点。
判断index是在前半区间还是后半区间,如果在前半区间就从head搜索,而在后半区间就从tail搜索。而不是一直从头到尾的搜索。如此设计,将节点访问的复杂度由O(n)变为O(n/2)。
相关推荐