欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++代碼實現(xiàn)鏈隊列詳解

 更新時間:2021年09月27日 10:18:14   作者:果醬包  
下面小編就為大家分享一篇C++代碼實現(xiàn)鏈隊列的示例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧,希望能夠給你帶來幫助

主要功能:

初始化、入隊出隊、取隊頭元素、銷毀隊列輸出隊列

完整代碼展示:

#include <iostream>
using namespace std;
#define MAXSIZE 100
typedef struct QueNode{  //定義鏈隊列存儲結(jié)構(gòu)
    int data;
    QueNode * next;
}QNode,*QuePtr;
typedef struct {  //定義鏈隊列指針
    QuePtr front;  //隊頭指針
    QuePtr rear;  //隊尾指針
}LinkQue;
bool InitQue(LinkQue &Q){  //初始化
    Q.front = Q.rear = new QNode;
    if (!Q.front) return false;
    Q.front->next = NULL;
    return true;
}
bool DestoryQue(LinkQue &Q){  //銷毀表
    while (Q.front){
        Q.rear = Q.front->next;
        delete(Q.front);
        Q.front = Q.rear;
    }
    return true;
}
bool EnQue(LinkQue &Q,int e){  //入隊
    QuePtr p = new QNode;
    if(!p) return false;
    p->data = e;
    p->next = NULL;
    Q.rear->next = p;
    Q.rear = p;
    return true;
}
bool OutQue(LinkQue &Q,int e){  //出隊
    if(Q.front == Q.rear) return false;  //隊空
    QuePtr p = Q.front->next;
    e = p->data;
    Q.front->next = p->next;
    if(Q.rear == p) Q.rear = Q.front;
    delete p;
    return true;
}
bool GetHead(LinkQue Q,int &e){  //取隊頭元素
    if(Q.front == Q.rear) return false;
    e = Q.front->next->data;
    return true;
}
void ShowList(LinkQue Q){   //輸出鏈隊
    QuePtr p = Q.front->next;
    while (p){
        cout<<p->data<<" ";
        p = p->next;
    }
    cout<<endl;
}
int main() {
    LinkQue Q;
    int e;
    int choose = -1;
    cout<<"1.入隊-------------------2.出隊"<<endl;
    cout<<"3.取頭元素---------------4.銷毀"<<endl;
    cout<<"5.輸出鏈隊---------------0.退出"<<endl;
    InitQue(Q);
    while (choose != 0) {
        cout << "請選擇功能:";
        cin >> choose;
        switch (choose) {
            case 1:
                cout << "請輸入入隊元素:";
                cin >> e;
                if (EnQue(Q, e))
                    cout << "入隊成功" << endl;
                break;
            case 2:
                if (OutQue(Q, e))
                    cout << "出隊成功" << endl;
                break;
            case 3:
                if (GetHead(Q, e))
                    cout << "隊頭元素為" << e << endl;
                break;
            case 4:
                if (DestoryQue(Q))
                    cout << "銷毀成功" << endl;
                break;
            case 5:
                cout << "隊列元素為:";
                ShowList(Q);
                break;
        }
    }
    return 0;
}

運行結(jié)果圖:

總結(jié)

本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!

相關(guān)文章

最新評論