数据结构 : 循环队列( 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. { 3. if(FullQueue(Q)) 4. return false; 5. else 6. { 7. Q-〉pBase[Q—〉rear]=val; 8. Q—>rear=(Q—〉rear+1)%Q-〉maxsize; 9. return true; 10. } 11. } 4。循环队列出队的伪算法(1)先保存出队的值;(2)front=(front+1)%maxsize ,其中 maxsize 代表数组的长度;程序代码:[cpp] view plain copy 1. bool Dequeue(PQUEUE Q, int *val) 2. { 3. if(EmptyQueue(Q)) 4. { 5. return false; 6. } 7. else 8. { 9. *val=Q—>pBase[Q—〉front]; 10. Q—>front=(Q-〉front+1)%Q—>maxsize; 11. return true; 12. } 13. } 5。如何推断循环队列是否为空if(front==rear)队列空;else 队列不空;[cpp] view plain copy 1. bool EmptyQueue(PQUEUE Q) 2. { 3. if(Q—>front==Q-〉rear) //推断是否为空 4. return true; 5. else 6. return false; 7. } 6.如何推断循环队列是否为满 这个问题比较复杂,假设数组的存数空间为 7,此时已经存放 1,a,5,7,22,90六个元素了,假如在往数组中添加一个元素,则 rear=front;此时,队列满与队列空的推断条件 front=rear 相同,这样的话我们就不能推断队列到底是空还是满了;解决这个问题有两个办法:...