棧和隊列(二)

隊列

代碼實現(xiàn)

#include<malloc.h> 
#include<stdio.h> 
#define OK 1
#define ERROR 0
typedef int Status;     // Status是函數(shù)的類型,其值是函數(shù)結果狀態(tài)代碼享扔,如OK等
typedef int QElemType;
#define MAXQSIZE 100    // 最大隊列長度(對于循環(huán)隊列,最大隊列長度要減1)

typedef struct
{
    QElemType *base;    // 初始化的動態(tài)分配存儲空間
    int front;          // 頭指針,若隊列不空,指向隊列頭元素
    int rear;           // 尾指針,若隊列不空,指向隊列尾元素的下一個位置
}SqQueue;


// 構造一個空隊列Q饼疙,該隊列預定義大小為MAXQSIZE
Status InitQueue(SqQueue &Q)   
{
    Q.base = (QElemType*)malloc(MAXQSIZE * sizeof(QElemType));
    if(!Q.base) return ERROR;
    Q.rear = Q.front = 0;
    return OK;
}


// 插入元素e為Q的新的隊尾元素
Status EnQueue(SqQueue &Q,QElemType e)  
{ 
    if((Q.rear+1)%MAXQSIZE==Q.front) return ERROR;
    Q.base[Q.rear]=e;
    Q.rear=(Q.rear+1)%MAXQSIZE;
    return OK;
}


// 若隊列不空, 則刪除Q的隊頭元素, 用e返回其值, 并返回OK; 否則返回ERROR
Status DeQueue(SqQueue &Q, QElemType &e) 
{  
    if(Q.front==Q.rear) return ERROR;
    e=Q.base[Q.front];
    Q.front=(Q.front+1)%MAXQSIZE;
    return OK;
}


// 若隊列不空裹赴,則用e返回隊頭元素报腔,并返回OK蜈彼,否則返回ERROR
Status GetHead(SqQueue Q, QElemType &e)
{   
    if(Q.front == Q.rear) return ERROR;
    e = Q.base[Q.front];
    return OK;
}


// 返回Q的元素個數(shù)
int QueueLength(SqQueue Q)  
{
    //return Q.rear - Q.front;
    //return Q.rear%MAXQSIZE-Q.front%MAXQSIZE
    return (Q.rear - Q.front + MAXQSIZE) % MAXQSIZE;
}


// 若隊列不空偎谁,則從隊頭到隊尾依次輸出各個隊列元素总滩,并返回OK;否則返回ERROR.
Status QueueTraverse(SqQueue Q)  
{
    int i;
    i=Q.front;
    if(Q.rear == Q.front)printf("The Queue is Empty!");  
    else
    {
        printf("The Queue is: ");
        while(i != Q.rear)     //請?zhí)羁?        {
            printf("%d ",Q.base[i] );  
            i = (i+1) % MAXQSIZE;  
        }
    }
    printf("\n");
    return OK;
}

int main()
{
    int a;
    SqQueue S;
    QElemType x, e;
    if(InitQueue(S))    // 判斷順序表是否創(chuàng)建成功
    {
        printf("A Queue Has Created.\n");
    }
    while(1)
    {
        printf("1:Enter \n2:Delete \n3:Get the Front \n4:Return the Length of the Queue\n5:Load the Queue\n0:Exit\nPlease choose:\n");
        scanf("%d",&a);
        switch(a)
        {
            case 1: 
                scanf("%d", &x);
                if(!EnQueue(S, x)) printf("Enter Error!\n"); // 判斷入隊是否合法
                else printf("The Element %d is Successfully Entered!\n", x); 
                break;
            case 2: 
                if(!DeQueue(S, e)) printf("Delete Error!\n"); // 判斷出隊是否合法
                else printf("The Element %d is Successfully Deleted!\n", e);
                break;
            case 3: 
                if(!GetHead(S, e))printf("Get Head Error!\n"); // 判斷Get Head是否合法
                else printf("The Head of the Queue is %d!\n", e);
                break;
            case 4: 
                printf("The Length of the Queue is %d!\n", QueueLength(S));
                break;
            case 5: 
                QueueTraverse(S);
                break;
            case 0: 
                return 1;
        }
    }
}
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末巡雨,一起剝皮案震驚了整個濱河市闰渔,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌铐望,老刑警劉巖冈涧,帶你破解...
    沈念sama閱讀 218,451評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異蝌以,居然都是意外死亡炕舵,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,172評論 3 394
  • 文/潘曉璐 我一進店門跟畅,熙熙樓的掌柜王于貴愁眉苦臉地迎上來咽筋,“玉大人,你說我怎么就攤上這事徊件〖楣ィ” “怎么了?”我有些...
    開封第一講書人閱讀 164,782評論 0 354
  • 文/不壞的土叔 我叫張陵虱痕,是天一觀的道長睹耐。 經(jīng)常有香客問我,道長部翘,這世上最難降的妖魔是什么硝训? 我笑而不...
    開封第一講書人閱讀 58,709評論 1 294
  • 正文 為了忘掉前任,我火速辦了婚禮新思,結果婚禮上窖梁,老公的妹妹穿的比我還像新娘。我一直安慰自己夹囚,他們只是感情好纵刘,可當我...
    茶點故事閱讀 67,733評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著荸哟,像睡著了一般假哎。 火紅的嫁衣襯著肌膚如雪瞬捕。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,578評論 1 305
  • 那天舵抹,我揣著相機與錄音肪虎,去河邊找鬼。 笑死掏父,一個胖子當著我的面吹牛笋轨,可吹牛的內容都是我干的。 我是一名探鬼主播赊淑,決...
    沈念sama閱讀 40,320評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼爵政,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了陶缺?” 一聲冷哼從身側響起钾挟,我...
    開封第一講書人閱讀 39,241評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎饱岸,沒想到半個月后掺出,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,686評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡苫费,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,878評論 3 336
  • 正文 我和宋清朗相戀三年汤锨,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片百框。...
    茶點故事閱讀 39,992評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡闲礼,死狀恐怖,靈堂內的尸體忽然破棺而出铐维,到底是詐尸還是另有隱情柬泽,我是刑警寧澤,帶...
    沈念sama閱讀 35,715評論 5 346
  • 正文 年R本政府宣布嫁蛇,位于F島的核電站锨并,受9級特大地震影響,放射性物質發(fā)生泄漏睬棚。R本人自食惡果不足惜第煮,卻給世界環(huán)境...
    茶點故事閱讀 41,336評論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望抑党。 院中可真熱鬧包警,春花似錦、人聲如沸新荤。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,912評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽苛骨。三九已至篱瞎,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間痒芝,已是汗流浹背俐筋。 一陣腳步聲響...
    開封第一講書人閱讀 33,040評論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留严衬,地道東北人澄者。 一個月前我還...
    沈念sama閱讀 48,173評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像请琳,于是被迫代替她去往敵國和親粱挡。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,947評論 2 355