队列(列举的不清楚的地方请类比“栈和队列——限定性线性表(一)”)
定义:队列是只允许在表的一端插入元素,而在另一端删除元素的一种限定性线性表。(允许删除的一端称为队头,允许插入的一端称为队尾)
特性:先进先出
队列的抽象数据类型三要素:数据元素,关系,基本操作
基本操作:初始化,判队是否为空,判队是否为满,进队,出队,取队头,清队,删除队列
存储方式:顺序存储,链式存储
队列的顺序存储(循环队列):因为只能在队头出队,在队尾入队,所以会产生假溢出现象。为解决假溢出,将顺序队列的数组看成一个环状的空间,即规定最后一个单元的后继为第一个单元,形象的称之为循环队列。(靠取模即求余运算来支持并实现循环队列。进队: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
栈和队列的共同点:都是运算位置受限制的线性表,都在表的端点进行运算操作
栈和队列的运算位置的区别:栈仅在表的一端操作,而队列在表的两端操作