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

学习时间

2021-01-17

学习内容

栈和队列的基本知识

队列是两种操作受限的线性表。允许在表的一端进行插入或删除操作,进行操作的一端称为栈顶,另一端称为栈底。队列允许在表的一端进行插入操作、在另一端进行删除操作。允许删除操作的一端称为队头,允许插入的一端称为队尾。插入操作也称入队、进队;删除操作也称出队、退队。

栈的顺序存储结构

  1. 顺序栈在入栈时要先判断栈是否已经满了,满了之后就不能入栈,否则会发生“上溢”现象
  2. 出栈和读栈顶元素操作时,要先盘算是否为空。若为空则不能操作。

栈的链式存储结构
为了避免栈上溢,可以采用链式存储结构。这样可以让多个栈共享所有可用空间,这种结构简称链栈。在一个链栈中,栈底就是链表的最后一个结点,栈顶是链表的第一个结点。

队列

队列的假溢出

就像在超市排队结账一样,队列在计算机的应用中也遵循这样一种先进先出的原则。为了避免当只有一个元素时,队头和队尾重合使处理变得麻烦,所以引入两个指针,front指针指向队头元素,rear指针指向队尾元素的下一个位置,这样当front等于rear时,此队列不是还剩一个元素,而是空队列。

假设是长度为5的数组,初始状态,空队列如所示,front与 rear指针均指向下标为0的位置。然后入队a1、a2、a3、a4, front指针依然指向下标为0位置,而rear指针指向下标为4的位置。
这里写图片描述

出队a1、a2,则front指针指向下标为2的位置,rear不变,如下图所示,再入队a5,此时front指针不变,rear指针移动到数组之外。嗯?数组之外,那将是哪里?

这里写图片描述

如果接着入队的话,因数组末尾元素已经占用,再向后加,就会产生数组越界的错误,可实际上,我们的队列在下标为0和1的地方还是空闲的。这种现象就是“假溢出”现象。

循环队列
为了解决“假溢出”问题,我们可以这样,将队列的首尾相连,让他形成一个环状的队列。就可以避免假溢出。

链队列
在使用循环队列的时候,首先要给它分配一个最大长度空间。但是这个长度空间往往不太好预估,所以可以采用链式结构来存储循环队列。称之为链队列

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值