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

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

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

主要功能:

初始化、入隊(duì)、出隊(duì)取隊(duì)頭元素、銷(xiāo)毀隊(duì)列、輸出隊(duì)列

完整代碼展示:

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

運(yùn)行結(jié)果圖:

總結(jié)

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

相關(guān)文章

  • 詳解安卓系統(tǒng)中的Android.mk文件

    詳解安卓系統(tǒng)中的Android.mk文件

    這篇文章主要介紹了詳解安卓系統(tǒng)中的Android.mk文件,該文件用來(lái)告訴系統(tǒng)關(guān)于源代碼的編譯,需要的朋友可以參考下
    2015-07-07
  • 詳解C語(yǔ)言中不同類(lèi)型的數(shù)據(jù)轉(zhuǎn)換規(guī)則

    詳解C語(yǔ)言中不同類(lèi)型的數(shù)據(jù)轉(zhuǎn)換規(guī)則

    這篇文章給大家講解不同類(lèi)型數(shù)據(jù)間的混合運(yùn)算與類(lèi)型轉(zhuǎn)換,有自動(dòng)類(lèi)型轉(zhuǎn)換和強(qiáng)制類(lèi)型轉(zhuǎn)換,針對(duì)每種轉(zhuǎn)換方法小編給大家介紹的非常詳細(xì),需要的朋友參考下吧
    2021-07-07
  • C++中靜態(tài)數(shù)據(jù)成員使用示例

    C++中靜態(tài)數(shù)據(jù)成員使用示例

    大家好,本篇文章主要講的是C++中靜態(tài)數(shù)據(jù)成員使用示例,感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話記得收藏一下,方便下次瀏覽
    2022-01-01
  • 數(shù)據(jù)結(jié)構(gòu) 中數(shù)制轉(zhuǎn)換(棧的應(yīng)用)

    數(shù)據(jù)結(jié)構(gòu) 中數(shù)制轉(zhuǎn)換(棧的應(yīng)用)

    這篇文章主要介紹了數(shù)據(jù)結(jié)構(gòu) 中數(shù)制轉(zhuǎn)換(棧的應(yīng)用)的相關(guān)資料,需要的朋友可以參考下
    2017-06-06
  • Objective-C不帶加減號(hào)的方法實(shí)例

    Objective-C不帶加減號(hào)的方法實(shí)例

    顯而易見(jiàn)的事實(shí)是,Objective-C 中,+ 表示類(lèi)方法,- 表示實(shí)例方法,這篇文章主要給大家介紹了關(guān)于Objective-C不帶加減號(hào)的相關(guān)資料,需要的朋友可以參考下
    2021-06-06
  • C++數(shù)據(jù)結(jié)構(gòu)與算法之雙緩存隊(duì)列實(shí)現(xiàn)方法詳解

    C++數(shù)據(jù)結(jié)構(gòu)與算法之雙緩存隊(duì)列實(shí)現(xiàn)方法詳解

    這篇文章主要介紹了C++數(shù)據(jù)結(jié)構(gòu)與算法之雙緩存隊(duì)列實(shí)現(xiàn)方法,結(jié)合實(shí)例形式分析了雙緩存隊(duì)列的原理、實(shí)現(xiàn)方法與相關(guān)注意事項(xiàng),需要的朋友可以參考下
    2017-08-08
  • C++的輸入和輸出流詳解

    C++的輸入和輸出流詳解

    這篇文章主要為大家詳細(xì)介紹了C++的輸入和輸出流,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助
    2022-03-03
  • C語(yǔ)言 共用體(Union)詳解及示例代碼

    C語(yǔ)言 共用體(Union)詳解及示例代碼

    本文主要介紹C語(yǔ)言 共用體,這里整理了相關(guān)資料及示例代碼,幫助大家學(xué)習(xí)理解此部分的知識(shí),有興趣的小伙伴可以參考下
    2016-08-08
  • C語(yǔ)言實(shí)現(xiàn)反彈球小游戲

    C語(yǔ)言實(shí)現(xiàn)反彈球小游戲

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)反彈球小游戲,利用函數(shù)寫(xiě)的C語(yǔ)言小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-02-02
  • Pthread?并發(fā)編程線程自底向上深入解析

    Pthread?并發(fā)編程線程自底向上深入解析

    這篇文章主要為大家介紹了Pthread?并發(fā)編程線程自底向上深入解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-11-11

最新評(píng)論