1完整代码
#include<iostream>
#include<malloc.h>
using namespace std;
#define TRUE 1
#define FALSE 0
#define OK 1
#define ERROR 0
#define OVERFLOW -2
typedef int QElemType;
typedef int Status;
typedef struct Qnode{
QElemType data;
struct Qnode *next;
}QNode, *QueuePtr;
typedef struct{
QueuePtr front;
QueuePtr rear;
}LinkQueue;
Status InitQueue(LinkQueue &Q)
{
Q.front = Q.rear = (QueuePtr)malloc(sizeof(QNode));
if ( !Q.front )
exit(OVERFLOW);
Q.front -> next = NULL;
return OK;
}
Status DestroyQueue(LinkQueue &Q)
{
while ( Q.front )
{
Q.rear = Q.front->next;
free(Q.front);
Q.front = Q.rear;
}
return OK;
}
Status EnQueue(LinkQueue &Q, QElemType e)
{
QueuePtr p = (QueuePtr)malloc(sizeof(Qnode));
if ( !p )
exit(OVERFLOW);
p->data = e;
p->next = NULL;
Q.rear->next = p;
Q.rear = p;
return OK;
}
Status DeQueue(LinkQueue &Q, QElemType &e)
{
QueuePtr p;
if ( Q.front == Q.rear )
return ERROR;
p = Q.front->next;
e = p->data;
Q.front->next = p->next;
if ( Q.rear == p )
Q.rear = Q.front;
free(p);
return OK;
}
Status GetHead(LinkQueue Q,QElemType &e)
{
if(Q.front == Q.rear)
return ERROR;
e = Q.front->next->data;
return OK;
}
void Enter_To_Queue(LinkQueue &Q)
{
int n;
QElemType e;
int flag;
printf("请输入入队元素个数(>=1):\n");
scanf("%d",&n);
for(int i=0;i<n;i++)
{
printf("请输入第%d个元素的值:",i+1);
scanf("%d",&e);
flag = EnQueue(Q,e);
if(flag)
printf("%d已入队\n",e);
}
}
void Delete_From_Queue(LinkQueue &Q)
{
int n;
QElemType e;
int flag;
printf("请输入出队元素个数(>=1):\n");
scanf("%d",&n);
for(int i=0;i<n;i++)
{
flag=DeQueue(Q,e);
if(flag)
printf("%d已出队\n",e);
else
{
printf("队已空!!!\n");
break;
}
}
}
void Get_Head_Of_Queue(LinkQueue &Q)
{
QElemType e;
bool flag;
flag = GetHead(Q,e);
if(flag)
printf("队头元素为:%d\n",e);
else
printf("队已空!!!\n");
}
int main()
{
LinkQueue Q;
InitQueue(Q);
Enter_To_Queue(Q);
Get_Head_Of_Queue(Q);
Delete_From_Queue(Q);
return 0;
}
2.测试结果
