为解决"假溢出"的问题,将顺序队列变为一个环状的空间,称为循环队列。头尾指针以及队列元素之间的关系不变,只是在循环队列中,头尾指针"依环状增1"的操作可用"模"运算来实现。通过取模,头指针和尾指针就可以在顺序表空间以头尾衔接的方式"循环"移动。
对于循环队列不能以头尾指针的值是否相同来判别队列空间是"满"还是"空",通常有两种处理方法:
1.少用一个元素空间,即队列空间大小为m时,有m-1个元素就认为是队满。这样判断队空的条件不变,即当头尾指针的值相同时,则认为队空;当尾指针在循环意义上+1后等于头指针,则认为队满。因此,在循环队列中队空和队满的条件是:
队空的条件是:Q.front == Q.rear;
<
C严蔚敏数据结构-循环队列
最新推荐文章于 2025-05-09 19:51:18 发布