#include<iostream>
using namespace std;
//该顺序队列为循环队列,解决队尾指针达到最大值,队列中有空闲单元,但新元素无法进入队列的情况
//
class
SeqQueue
{
int
*data;
int front;
int
rear;
int cap;
//存储队列容量
int
length; //当前队列长度
public:
SeqQueue(int length)
{
data=NULL;//data初始化为NULL,用于后面的if语句判断
data=new int[length]; //分配数组空间
this->cap=length;
if(!data)
{
cout<<"OVERFLOW"<<endl;
return;
}
front=rear=0;
this->length=0; //当前长度初始化为0
cout<<"The
Queue is constructed"<<endl;
}
void EnQueue(int e) //入列函数
{
if((rear+1)%cap==front)
{
cout<<"The queue is full"<<endl;
return;
}
length++;
data[rear]=e;
rear=(rear+1)%cap; //判断是否超出最大值,超出时回到起点
}
void DeQueue(int &e)
//出列
{
if(front==rear)
{
cout<<"The queue is empty"<<endl;
return;
}
e=data[front];
length--;
front=(front+1)%cap;
}
void show() //显示队列所有节点,
{
if(front==rear)
{
cout<<"The queue is
empty"<<endl;
return;
}
int q=front;
int i=1;
while(q!=rear)
{
cout<<"The"<<i<<"th queue node is: "<<data[q]<<endl;
q=(q+1)%cap;
i++;
}
cout<<"_________________________________"<<endl;
}
};
void
main()
{
SeqQueue a(4);
int num;
a.EnQueue(1);
a.DeQueue(num);
a.DeQueue(num);
a.EnQueue(2);
a.DeQueue(num);
a.EnQueue(3);
a.EnQueue(4);
a.EnQueue(5);
a.EnQueue(6);
a.show();
}
数据结构6_顺序队列(循环队列),布布扣,bubuko.com
原文:http://www.cnblogs.com/zhuangwy-cv/p/3755188.html