数据结构与算法

第三章  栈和队列

栈的相关概念
定义:栈是限制在表的一端进行插入和删除运算的线性表
栈顶、栈底、空栈
特点:栈的修改是按后进先出的原则进行->后进先出表
栈的基本操作
初始化、进栈、退栈、取栈顶元素、判断是否为空栈、置栈空
栈的表示和实现
存储方式:顺序存储和链式存储
顺序存储:每当插入新的栈顶元素时候,指针top+1 删除栈顶元素时候,指针top-1,非空栈中的栈顶指针始终在栈顶元素的下一个位置上。
链式存储:它是运算受限的单链表,插入和删除操作仅限制在表头位置进行,由于只能在链表头部进行操作,故链表没有必要像单链表那样附设头结点,栈顶指针就是链表的头指针。
栈的应用
1、数值转换
2、括号匹配的检验
3、行编辑程序问题
4、迷宫求解
5、表达式求值
6、栈与递归的实现
7、汉诺塔问题
队列
队列的相关概念
1、定义:队列是一种运算首先得线性表,它允许在表的一端进行插入,而在另一端进行删除。允许删除的一端称为对头,允许插入的一端叫队尾。
2、特点:先进先出原则
队列的存储结构
链队列:它是限制仅在表头删除和表尾插入的单链表->设有两个指针:front指向队头,rear指向队尾
循环队列——队列的顺序表示和实现->用一组地址连续的存储单元存放从对头和队尾的元素->设有两个指针:front=rear=0->每当插入新的队列尾元素时候,尾指针+1,每当删除一个元素的时候,头指针+1
综上:头指针总是指向队头元素,而尾指针始终指向队尾元素的下一个位置
循环队列的计算问题:

6e12705360224e04b36d8321973a7363.png

循环队列的提出就是为了解决假溢出问题:真加溢出问题的实质是:队列中是否有空闲的空间

521ba7ebf33a4a1aaa70c6126878fc2a.png
 

f2c50db3b9de4e0b858155b6aa8a0864.png

 5ba9fba9c0e14f0f9174b0bb54acfb81.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值