登录
/
注册
首页
论坛
其它
首页
科技
业界
安全
程序
广播
Follow
关于
导读
排行榜
资讯
发帖说明
登录
/
注册
账号
自动登录
找回密码
密码
登录
立即注册
搜索
搜索
关闭
CSDN热搜
程序园
精品问答
技术交流
资源下载
本版
帖子
用户
软件
问答
教程
代码
写记录
写博客
小组
VIP申请
VIP网盘
网盘
联系我们
发帖说明
道具
勋章
任务
淘帖
动态
分享
留言板
导读
设置
我的收藏
退出
腾讯QQ
微信登录
返回列表
首页
›
业界区
›
业界
›
重生之数据结构与算法----队列&栈
重生之数据结构与算法----队列&栈
[ 复制链接 ]
呼延含玉
2025-6-4 22:21:18
程序园永久vip申请,500美金$,无限下载程序园所有程序/软件/数据/等
简介
上文说到,数据结构只有两种。其它的数据结构都是它的整花活。
栈
栈只能在表的一端(称为栈顶)进行插入和删除操作,遵循 “后进先出”(Last In First Out,LIFO)的原则。就像生活中的一摞盘子,最后放上去的盘子会最先被拿走
队列
它只允许在表的一端进行插入操作(队尾),在另一端进行删除操作(队头),遵循 “先进先出”(First In First Out,FIFO)的原则。类似于生活中排队买票,先排队的人先买到票离开队列。
用链表实现stack
public class MyLinkedStack<T>()
{
public static void Run()
{
var stack = new MyLinkedStack<string>();
stack.Push("aaaa");
stack.Push("bbbb");
stack.Push("cccc");
stack.Push("dddd");
while (stack.Count > 0)
{
Console.WriteLine(stack.Pop());
}
}
private LinkedList<T> _linked = new LinkedList<T>();
/// <summary>
/// 入栈
/// O(1)
/// </summary>
/// <param name="item"></param>
public void Push(T item)
{
_linked.AddFirst(item);
}
/// <summary>
/// 出栈
/// O(1)
/// </summary>
/// <returns></returns>
public T Pop()
{
var first = _linked.First;
_linked.RemoveFirst();
return first.Value;
}
/// <summary>
/// 查看栈顶
/// </summary>
/// O(1)
/// <returns></returns>
public T Peek()
{
return _linked.First.Value;
}
public int Count { get { return _linked.Count; } }
}
复制代码
用链表实现queue
public class MyLinkedQueue<T>
{
public static void Run()
{
var queue = new MyLinkedQueue<string>();
queue.Enqueue("aaa");
queue.Enqueue("bbb");
queue.Enqueue("ccc");
queue.Enqueue("ddd");
while (queue.Count > 0)
{
Console.WriteLine(queue.Dequeue());
}
}
private LinkedList<T> _linked = new LinkedList<T>();
/// <summary>
/// 入列
/// </summary>
/// <param name="item"></param>
public void Enqueue(T item)
{
_linked.AddFirst(item);
}
/// <summary>
/// 出列
/// </summary>
/// <returns></returns>
public T Dequeue()
{
var last= _linked.Last;
_linked.RemoveLast();
return last.Value;
}
/// <summary>
/// 查看队列顶
/// </summary>
/// <returns></returns>
public T Peek()
{
return _linked.First.Value;
}
public int Count { get { return _linked.Count; } }
}
复制代码
用数组实现stack
public class MyArrayStack<T>()
{
public static void Run()
{
var stack = new MyLinkedStack<string>();
stack.Push("aaaa");
stack.Push("bbbb");
stack.Push("cccc");
stack.Push("dddd");
while (stack.Count > 0)
{
Console.WriteLine(stack.Pop());
}
}
private List<T> _list=new List<T>();
/// <summary>
/// 入栈
/// O(1)
/// </summary>
/// <param name="item"></param>
public void Push(T item)
{
_list.Add(item);
}
/// <summary>
/// 出栈
/// O(1)
/// </summary>
/// <returns></returns>
public T Pop()
{
var v = _list[_list.Count - 1];
_list.RemoveAt(_list.Count - 1);
return v;
}
/// <summary>
/// 查看栈顶
/// </summary>
/// O(1)
/// <returns></returns>
public T Peek()
{
return _list[_list.Count - 1];
}
public int Count { get { return _list.Count; } }
}
复制代码
用数组实现queue
由于queue先进先出的特性,list头部增删元素的复杂度是O(N),不符合性能要求,我们可以使用前文介绍的环形数组,来实现list头部增删的O(1)
public class MyArrayQueue<T>
{
public static void Run()
{
var queue = new MyArrayQueue<string>();
queue.Push("aaaa");
queue.Push("bbbb");
queue.Push("cccc");
queue.Push("dddd");
while (queue.Count > 0)
{
Console.WriteLine(queue.Pop());
}
}
private CircularArray<T> _list = new CircularArray<T>();
/// <summary>
/// 入栈
/// O(1)
/// </summary>
/// <param name="item"></param>
public void Push(T item)
{
_list.AddFirst(item);
}
/// <summary>
/// 出栈
/// O(1)
/// </summary>
/// <returns></returns>
public T Pop()
{
var v = _list.GetLast();
_list.RemoveLast();
return v;
}
/// <summary>
/// 查看栈顶
/// </summary>
/// O(1)
/// <returns></returns>
public T Peek()
{
return _list.GetFirst();
}
public int Count { get { return _list.Count; } }
}
复制代码
队列的变种:双端队列
所谓双端队列,主要是比普通队列,多一个出入口,可以从队列的两头进行插入,删除。但也破坏了先进先出的原则。
日常场景使用不多。只有 Python用得多一些,因为Python标准库没有提供内置的栈和队列,一般会用双端队列来模拟标准队列。
public interface IMyQueue<T>
{
/// <summary>
/// 从头入列
/// </summary>
/// <param name="item"></param>
void EnqueueFirst(T item);
/// <summary>
/// 从头出列
/// </summary>
/// <param name="item"></param>
/// <returns></returns>
T DequeueFirst(T item);
/// <summary>
/// 从尾入列
/// </summary>
void EnqueueLast();
/// <summary>
/// 从头出列
/// </summary>
/// <returns></returns>
T DequeueLast();
}
复制代码
实现比较简单,不再重复,参考普通队列思路即可。链表/环形数组均可实现。
来源:程序园用户自行投稿发布,如果侵权,请联系站长删除
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
重生
数据结构
算法
队列
amp
相关帖子
目标追踪算法+卡尔曼滤波原理+ByteTrack使用
一只菜鸟学深度学习的日记:填充 & 步幅 & 下采样
【低代码】低代码平台协同&敏捷场景下的并行开发解决方案探索
查找算法
[数据结构/Java] 数据结构之循环队列
数字电路模拟程序&课堂测验Blog
【分析式AI】-朴素贝叶斯算法模型
【分析式AI】-朴素贝叶斯算法模型
负载均衡的概念、分类、算法、健康检查机制及高可用解决方案
回复
使用道具
举报
提升卡
置顶卡
沉默卡
喧嚣卡
变色卡
千斤顶
照妖镜
相关推荐
业界
目标追踪算法+卡尔曼滤波原理+ByteTrack使用
1
480
娥搽裙
2025-12-09
业界
一只菜鸟学深度学习的日记:填充 & 步幅 & 下采样
1
198
喙审
2025-12-10
安全
【低代码】低代码平台协同&敏捷场景下的并行开发解决方案探索
0
472
杓疠?
2025-12-11
业界
查找算法
2
37
崔瑜然
2025-12-12
安全
[数据结构/Java] 数据结构之循环队列
0
490
豺独
2025-12-14
安全
数字电路模拟程序&课堂测验Blog
0
217
吕梓美
2025-12-15
业界
【分析式AI】-朴素贝叶斯算法模型
0
221
跑两獗
2025-12-16
业界
【分析式AI】-朴素贝叶斯算法模型
0
275
巫雪艷
2025-12-16
安全
负载均衡的概念、分类、算法、健康检查机制及高可用解决方案
0
282
渭茱瀑
2025-12-16
回复
(4)
轩辕娅童
2025-10-17 13:54:53
回复
使用道具
举报
照妖镜
程序园永久vip申请,500美金$,无限下载程序园所有程序/软件/数据/等
很好很强大 我过来先占个楼 待编辑
段干叶农
2025-10-24 00:44:49
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
感谢分享
赘暨逢
2025-11-10 12:23:29
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
鼓励转贴优秀软件安全工具和文档!
晌集涟
7 天前
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
用心讨论,共获提升!
师悠逸
6 天前
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
新版吗?好像是停更了吧。
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
|
立即注册
回复
本版积分规则
回帖并转播
回帖后跳转到最后一页
浏览过的版块
程序
安全
签约作者
程序园优秀签约作者
发帖
呼延含玉
6 天前
关注
0
粉丝关注
30
主题发布
板块介绍填写区域,请于后台编辑
财富榜{圆}
3934307807
991124
anyue1937
9994893
kk14977
6845357
4
xiangqian
638210
5
韶又彤
9997
6
宋子
9983
7
闰咄阅
9993
8
刎唇
9993
9
俞瑛瑶
9998
10
蓬森莉
9951
查看更多
今日好文热榜
809
Flink学习笔记:反压
694
JUnit 5 中的 @ClassTemplate 实战指南
226
Java 25 (LTS) 重磅发布:AI、性能、安全全
283
Java 25 (LTS) 重磅发布:AI、性能、安全全
280
负载均衡的概念、分类、算法、健康检查机制
738
Prompt 工程
499
Prompt 工程
759
Gemini 3.0 Pro 迁移避坑指南:OpenAI API
21
是猫踩键盘还是乱码?不,这是你刚写的正则
249
RSA加密
318
pydash原型链污染
180
大模型榜单周报(2025/12/08—2025/12/12)
851
当你不再迷信“最强模型”,系统设计才刚刚
877
软件i2c
303
2025年专业起名老师联系方式汇总:全国资深
654
解码IP协议号:网络世界的“货物运单”
712
Python Selenium 漫步指南:从入门到精通
646
AI 付费模式终极对比:ChatGPT、Gemini、Cl
840
JSAPIThree 加载 3D Tiles 学习笔记:大规
360
LLM 工具调用的范式演进与认知模型集成