#include <iostream>
using namespace std;
#define MaxSize 10
typedef struct QNode{
int data;
struct QNode*next;
}QNode;
typedef struct {
QNode*front;
QNode*rear;
}LinkQueue;
void InitQueue(LinkQueue &que);
bool IsEmpty(LinkQueue que);
bool enQueue(LinkQueue &que,int x);
bool deQueue(LinkQueue &que,int &x);
int Length(LinkQueue que);
int main()
{
LinkQueue que;
InitQueue(que);
for(int i=0;i<5;i++)
{
cout<<enQueue(que,i)<<endl;
}
cout<<IsEmpty(que)<<endl;
cout<<Length(que)<<endl;
int ans;
cout<<deQueue(que,ans);
cout<<Length(que)<<endl;
}
void InitQueue(LinkQueue &que)
{
que.front=que.rear=(QNode*)malloc(sizeof(QNode));
que.front->next=NULL;
}
bool IsEmpty(LinkQueue que)
{
return (que.front==que.rear);
}
bool enQueue(LinkQueue &que,int x)
{
QNode*s=(QNode*)malloc(sizeof(QNode));
s->data=x;
s->next=NULL;
que.rear->next=s;
que.rear=s;
return true;
}
bool deQueue(LinkQueue &que,int &x)
{
if(que.front==que.rear)return false;
QNode*p=que.front->next;
x=p->data;
que.front->next=p->next;
if(que.rear==p)
que.rear=que.front;
free(p);
return true;
}
int Length(LinkQueue que)
{
QNode*p;
p=que.front;
int k=0;
while(p->next)
{
k++;
p=p->next;
}
return k;
}