栈和队列——限定性线性表(二)

队列(列举的不清楚的地方请类比“栈和队列——限定性线性表(一)”)

       定义:队列是只允许在表的一端插入元素,而在另一端删除元素的一种限定性线性表。(允许删除的一端称为队头,允许插入的一端称为队尾)

       特性:先进先出

       队列的抽象数据类型三要素:数据元素,关系,基本操作

                                                      基本操作:初始化,判队是否为空,判队是否为满,进队,出队,取队头,清队,删除队列

       存储方式:顺序存储,链式存储

                         队列的顺序存储(循环队列):因为只能在队头出队,在队尾入队,所以会产生假溢出现象。为解决假溢出,将顺序队列的数组看成一个环状的空间,即规定最后一个单元的后继为第一个单元,形象的称之为循环队列。(靠取模即求余运算来支持并实现循环队列。进队:rear=(rear+1)%size或出队:front=(front+1)%size。rear是尾指针,front是头指针,size为数组的长度)

                         循环队列中:判断队空和队满的方法:1.损失一个元素空间:

                                                                                          队空(f=r):队头指针和队尾指针指向同一个

                                                                                          队满(f=r+1):队头指针指向实际队头,队尾指针指向实际队尾的下一个(一般情况也这样)

                                                                                       2.增设一个标志量

                                               求元素个数:1.r>f时,n=r-f

                                                                     2.r<f时,n=size-(f-r)=(r-f)+size

                                                                     总的来说,n=(r-f+size)%size

栈和队列的共同点:都是运算位置受限制的线性表,都在表的端点进行运算操作

栈和队列的运算位置的区别:栈仅在表的一端操作,而队列在表的两端操作

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值