链表效率
|
无序数组 |
有序数组 |
查找 |
比较次数O(N) |
比较次数O(logN)<—二分查找 |
插入 |
O(1) |
比较次数O(N) |
|
|
移动次数MaxO(N) |
删除 |
比较次数O(N) |
比较次数O(logN) |
|
移动次数MaxO(N) |
移动次数MaxO(N) |
|
单链表 |
双端链表 |
有序链表 |
双向链表 |
头插 |
O(1) |
|
|
O(1) |
头删 |
O(1) |
|
|
O(1) |
尾插 |
|
O(1) |
|
O(1) |
尾删 |
|
O(N) |
|
O(1) |
插入 |
|
|
Max O(N) | Min O(N/2) |
|
删除 |
|
|
O(1) |
|
查找结点 |
O(N) 次比较 无移动次数 |
|
|
|
删除结点 |
O(N) 次比较 无移动次数 |
|
|
O(N) – deleteKey(int i) |
指定结点后插入 |
O(N) 次比较 无移动次数 |
|
|
O(N) – insertAfter(int i) |
链表优点
l 使用内存无限制 可以扩展到所有可以使用的内存
数组大小在创建的时候 就固定了经常由于数组太大 导致效率低下 或者数组太小导致空间溢出
l 插入删除结点的时候 链表不需要任何移动 特别是复制时间远远大于比较时间的时候
双向链表
优点:
前向遍历
后向遍历
缺点:
每次插入或者删除一个链结点时候 需要处理四个连结点的引用(2个连接前一个链结点 两个链接后一个)由于多了两个引用 连结点占用的空间也变大了
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步