//隊列的基本操做 node
#include <iostream> ios
using namespace std;ide
#define datatype intspa
#define Status int隊列
#define OK 1it
#define ERROR 0io
typedef struct linkqueuenode{ //定義隊列節點 class
datatype data;stream
struct linkqueuenode *next; 遍歷
}LinkQueueNode;
typedef struct { //定義鏈式隊列
LinkQueueNode *front;
LinkQueueNode *rear;
}LinkQueue;
//初始化
void InitQueue(LinkQueue *q)
{
q->front=NULL;
q->rear=NULL;
}
//入隊
Status InQueue(LinkQueue *q,datatype x)
{
//建立節點
LinkQueueNode *s=new LinkQueueNode;
s->data=x;
s->next=NULL;
//是否隊空
if(q->front==NULL)
{
s->next=q->rear;
q->front=s;
q->rear=s;
}
else
{
q->rear->next=s;
q->rear=s;
}
return 0;
}
//出隊
Status OutQueue(LinkQueue *q,datatype &x)
{//若隊空,返回0;出隊完成,返回1
if(NULL==q->front) return 0;
LinkQueueNode *p=q->front;
x=p->data;
q->front=p->next;
delete p;
return 1;
}
//顯示隊列元素
Status ShowQueue(LinkQueue *q)
{
if(q->front==NULL) {cout<<"棧空!"<<endl;return 0;}//隊列空
LinkQueueNode *p;
p=q->front;
cout<<"遍歷隊列: ";
while(p!=NULL)
{
printf("%d ",p->data);
p=p->next;
}
cout<<endl;
return 1;
}
//讀隊首元素
Status ReadQueue(LinkQueue *q)
{
if(NULL==q->front) return 0;
cout<<"隊首元素爲:"<<q->front->data<<endl;;
return 1;
}
//雙隊列,隊首出棧
Status OutQueueFront(LinkQueue *q,datatype &x)
{//若隊空,返回0;出隊完成,返回1
if(NULL==q->front) return 0;
LinkQueueNode *p=q->front;
x=p->data;
q->front=p->next;
delete p;
return 1;
}
//雙隊列,隊尾出棧
Status OutQueueRear(LinkQueue *q,datatype &x)
{
//對空,返回0
if(NULL==q->front) return 0;
//找q.rear的前驅
LinkQueueNode *ptr;
ptr=q->rear;//ptr指向對尾
LinkQueueNode *p=q->front;
while(p->next!=q->rear)//p指向q->rear的前驅
{
p=p->next;
}
x=q->rear->data;
p->next=q->rear->next;
q->rear->next=p->next;
q->rear=p;
delete ptr;
return 1;
}
int main()
{
LinkQueue que;//建立隊列
InitQueue(&que);//初始化隊列
InQueue(&que,1);//入隊
InQueue(&que,2);
InQueue(&que,3);
InQueue(&que,4);
ShowQueue(&que);//1,2,3,4
datatype temp;//用於保存出隊的data
OutQueue(&que,temp);//2,3,4
ShowQueue(&que);//顯示隊列元素
ReadQueue(&que);
OutQueueRear(&que,temp);//2,3
ShowQueue(&que);
system("pause");
return 0;
}
-----------------------------------------------------------
運行結果:
遍歷隊列: 1 2 3 4
出隊!:
遍歷隊列: 2 3 4
隊首元素爲:2
隊尾出隊!
遍歷隊列: 2 3
Press any key to continue . . .
鮮少偉
2016-4-18