3.2.3队列的链接实现
 // DataStructTest.cpp : Defines the entry point for the console application.
// DataStructTest.cpp : Defines the entry point for the console application. //
//
 #include "stdafx.h"
#include "stdafx.h" #include <iostream.h>
#include <iostream.h> #include <malloc.h>
#include <malloc.h>
 typedef struct linked_queue
typedef struct linked_queue {
{ int data;
    int data; struct linked_queue * next;
    struct linked_queue * next; }LqueueTp;
}LqueueTp; typedef struct queueptr
typedef struct queueptr {
{ LqueueTp * front;
    LqueueTp * front; LqueueTp * rear;
    LqueueTp * rear;
 }QueptrTp;
}QueptrTp;
 //初始化.申请一个结点且不存储信息,只作为判断是否为空结点的标志
//初始化.申请一个结点且不存储信息,只作为判断是否为空结点的标志 void InitQueue(QueptrTp & lq)
void InitQueue(QueptrTp & lq) {
{ LqueueTp * p=NULL;
    LqueueTp * p=NULL; while(lq.front!=NULL)
    while(lq.front!=NULL) {
    { p=lq.front;
        p=lq.front; lq.front=lq.front->next;
        lq.front=lq.front->next; free(p);
        free(p); }
    } lq.front=lq.rear=NULL;
    lq.front=lq.rear=NULL; p=(LqueueTp *)malloc(sizeof(linked_queue));
    p=(LqueueTp *)malloc(sizeof(linked_queue)); p->next=NULL;
    p->next=NULL; lq.front=lq.rear=p;
    lq.front=lq.rear=p; }
} //入队
//入队 void EnQueue(QueptrTp & lq,int value)
void EnQueue(QueptrTp & lq,int value) {
{ LqueueTp * p=(LqueueTp *)malloc(sizeof(linked_queue));
    LqueueTp * p=(LqueueTp *)malloc(sizeof(linked_queue)); p->data=value;
    p->data=value; p->next=NULL;
    p->next=NULL; //修改队尾结点指向新的结点后,再将尾结点指向新增的结点
    //修改队尾结点指向新的结点后,再将尾结点指向新增的结点 lq.rear->next=p;
    lq.rear->next=p; lq.rear=p;
    lq.rear=p; }
} //出队
//出队 int OutQueue(QueptrTp & lq,int & value)
int OutQueue(QueptrTp & lq,int & value) {
{ if (lq.front==lq.rear)
    if (lq.front==lq.rear) {
    { return 0;
        return 0; }
    }
 //得到首节点的值.因为lq.front指向的是标志结点,所以要指向next后面的结点的data
    //得到首节点的值.因为lq.front指向的是标志结点,所以要指向next后面的结点的data value=lq.front->next->data;
    value=lq.front->next->data; //使首结点指向下一个结点作为了标志结点,然后释放原首结点的空间
    //使首结点指向下一个结点作为了标志结点,然后释放原首结点的空间 LqueueTp * p=lq.front;
    LqueueTp * p=lq.front; lq.front=lq.front->next;
    lq.front=lq.front->next; free(p);
    free(p); return 1;
    return 1; }
} //判断是否为空
//判断是否为空 int EmptyQueue(QueptrTp & lq)
int EmptyQueue(QueptrTp & lq) {
{ if (lq.front==lq.rear)
    if (lq.front==lq.rear) return 1;
        return 1; else
    else return 0;
        return 0; }
} //得到队头结点的值
//得到队头结点的值 int GetHead(QueptrTp & lq,int & value)
int GetHead(QueptrTp & lq,int & value) {
{ if (lq.front==lq.rear)
    if (lq.front==lq.rear) {
    { return 0;
        return 0; }
    } value=lq.front->next->data;
    value=lq.front->next->data; return 1;
    return 1; }
} //显示
//显示 void Display(QueptrTp & lq)
void Display(QueptrTp & lq) {
{ LqueueTp * p=lq.front->next;
    LqueueTp * p=lq.front->next; while(p!=NULL)
    while(p!=NULL) {
    { cout<<"队列中的元素为:"<<p->data<<endl;
        cout<<"队列中的元素为:"<<p->data<<endl; p=p->next;
        p=p->next; }
    } }
}
 int main(int argc, char* argv[])
int main(int argc, char* argv[]) {
{ QueptrTp lq;
    QueptrTp lq; lq.front=NULL;
    lq.front=NULL; lq.rear=NULL;
    lq.rear=NULL; InitQueue(lq);
    InitQueue(lq); //入队
    //入队 for(int i=1;i<20;i++)
    for(int i=1;i<20;i++) {
    { EnQueue(lq,i);
        EnQueue(lq,i); }
    } Display(lq);
    Display(lq); //出队
    //出队 int value=0;
    int value=0; OutQueue(lq,value);
    OutQueue(lq,value); cout<<"出队的结点值为:"<<value<<endl;
    cout<<"出队的结点值为:"<<value<<endl; Display(lq);
    Display(lq); //
    // EnQueue(lq,500);
    EnQueue(lq,500); cout<<endl;
    cout<<endl; Display(lq);
    Display(lq); return 0;
    return 0; }
}
    一点说明:为什么在标题中要嵌入英文?原因是为了能够让国外的网友能查询到这篇文章。平常在Google上查资料的时候,经常参考国外网友的博客,帮助我解决了很多问题,所以我也想让他们能够参考我写的内容。当然文中我不可能全部译为英文,所以我尽量把代码粘全,靠代码说话吧。
 
                     
                    
                 
                    
                


 
     
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号