链表用途&&数组效率&&链表效率&&链表优缺点

本文详细探讨了数据结构栈、队列、优先级队列、双端队列的实现方式及数组与链表的比较,重点分析了它们在查找、插入、删除操作上的效率差异。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

三大数据结构的实现方式
数据结构实现方式
栈 数组/单链表
队列 数组/双端链表
优先级队列数组//有序链表
双端队列双向链表

 

数组与链表实现方式的比较

数组与链表都很快

如果能精确预测栈或者队列所需要容纳的数据量 --- 数组

如果不能                                   --- 链表

数组的效率

 

无序数组

有序数组

查找

比较次数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个连接前一个链结点 两个链接后一个)由于多了两个引用 连结点占用的空间也变大了

转载于:https://www.cnblogs.com/cici-new/p/3237276.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值