数据结构----栈和队列


一、什么是栈?

栈的概念及结构

栈:一种特殊的线性表,期允许在固定的一端进行插入和删除元素操作。进行数据插入和删除操作的- -端称为栈顶,另一端称为栈底。栈中的数据元素遵守后进先出LIFO (Last In First Out)的原则。

压栈:栈的插入操作叫做进栈/压栈入栈,入数据在栈顶

出栈:栈的删除操作叫做出栈。出数据也在栈顶
在这里插入图片描述

二、基本操作

定义

在这里插入图片描述

初始化

在这里插入图片描述

初始化时,top给的是0,意味着top指向栈顶数据的下一个
初始化时,top给的是-1,意味着top指向栈顶数据

销毁

在这里插入图片描述

插入

在这里插入图片描述

删除

在这里插入图片描述

栈是否为空

在这里插入图片描述

取栈顶数据

在这里插入图片描述

队列

队列的概念:
在这里插入图片描述

用数组结构不太适合,出数据要挪动数据,队尾入,队头出,链表头删和找尾比较简单,所以用链式结构比较合适。
链表只需要头指针即可,此处我们需要头指针和尾指针

队列定义

在这里插入图片描述

初始化和销毁

在这里插入图片描述

队列尾插

在这里插入图片描述

队列删除

在这里插入图片描述

注:free的不是指针b本身,而是指针指向的空间。

队列取头尾

在这里插入图片描述

队列大小

在这里插入图片描述


三、总结

栈和队列的共同点:
1.都是线性结构。
2.栈和队列的共同点是只允许在端点处插入和删除元素。
3.插入与删除的时间复杂度都是O(1),在空间复杂度上两者也一样。

栈和队列的区别
1. 栈和队列的出入方式不同:栈是后进先出、队列是先进先出。
2. 删除数据元素的位置不同,栈的删除操作在表尾进行,队列的删除操作在表头进行。

最后,码字不易,如果觉得对你有帮助的话请点个赞吧,关注我,一起学习,一起进步!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值