数据结构 : 循环队列( C 语言实现) 生活中有很多队列的影子,比如打饭排队,买火车票排队问题等,可以说与时间相关的问题,一般都会涉及到队列问题;从生活中,可以抽象出队列的概念,队列就是一个能够实现“先进先出”的存储结构
队列分为链式队列和静态队列;静态队列一般用数组来实现,但此时的队列必须是循环队列,否则会造成巨大的内存浪费;链式队列是用链表来实现队列的
这里讲的是循环队列,首先我们必须明白下面几个问题一、循环队列的基础知识1
循环队列需要几个参数来确定循环队列需要 2 个参数,front 和 rear2
循环队列各个参数的含义(1)队列初始化时,front 和 rear 值都为零;(2)当队列不为空时,front 指向队列的第一个元素,rear 指向队列最后一个元素的下一个位置;(3)当队列为空时,front 与 rear 的值相等,但不一定为零;3
循环队列入队的伪算法(1)把值存在 rear 所在的位置;(2)rear=(rear+1)%maxsize ,其中 maxsize 代表数组的长度;程序代码:[cpp] view plain copy 1
bool Enqueue(PQUEUE Q, int val) 2
if(FullQueue(Q)) 4
return false; 5
else 6
Q-〉pBase[Q—〉rear]=val; 8
Q—>rear=(Q—〉rear+1)%Q-〉maxsize; 9
return true; 10
循环队列出队的伪算法(1)先保存出队的值;(2)front=(front+1)%maxsize ,其中 maxsize 代表数组的长度;程序代码:[cpp] view plain copy 1
bool Dequeue(PQUEUE Q, int *val) 2