五茂契、棧和隊(duì)列(一)蝶桶、棧

數(shù)據(jù)結(jié)構(gòu)目錄

1.定義

棧(stack)是一個(gè)后進(jìn)先出(Last in first out,LIFO)的線(xiàn)性表,它要求只在表尾進(jìn)行刪除和插入操作掉冶。
棧在操作上有一些特殊的要求和限制:

  • 棧的元素必須后進(jìn)先出
  • 棧的操作只能在這個(gè)線(xiàn)性表的表尾進(jìn)行
  • 對(duì)于棧來(lái)說(shuō)真竖,這個(gè)表尾成為棧的棧定(top),相應(yīng)的表頭稱(chēng)為棧底(bottom)

2.棧的插入和刪除操作

  • 棧的插入操作(push),叫做進(jìn)棧厌小,也成為壓棧恢共,入棧。
  • 棧的刪除操作(pop),叫做出棧璧亚,也稱(chēng)為彈棧讨韭。

3. 棧的順序存儲(chǔ)結(jié)構(gòu)

因?yàn)闂5谋举|(zhì)是一個(gè)線(xiàn)性表,線(xiàn)性表有兩種存儲(chǔ)形式癣蟋,那么棧也有分為棧的順序存儲(chǔ)結(jié)構(gòu)和棧的鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu)
最開(kāi)始棧中不含有任何數(shù)據(jù)透硝,叫做空棧,此時(shí)棧頂就是棧底疯搅。然后數(shù)據(jù)從棧頂進(jìn)入濒生,棧頂棧底分離,整個(gè)棧的當(dāng)前容量變大幔欧。數(shù)據(jù)出棧時(shí)從棧頂彈出罪治,棧頂下移,整個(gè)棧的當(dāng)前容量變小琐馆。

棧的順序存儲(chǔ)結(jié)構(gòu)
(1)棧的結(jié)構(gòu)定義
#define STACK_INIT_SIZE 100
#define STACKINCREMENT 10
typedef struct SqStack{
    ElemType *base;//棧底
    ElemType *top;//棧頂
    int stackSize;
}SqStack;
(2)初始化一個(gè)空棧
Status initStack(SqStack *s){
    s->base = (ElemType *)malloc(sizeof(ElemType) * STACK_INIT_SIZE);
    if (!(s->base)) {
        return ERROR;
    }
    s->top = s->base;//最開(kāi)始规阀,棧頂就是棧底,代表它是一個(gè)空棧
    s->stackSize = STACK_INIT_SIZE;
    return OK;
}
(3)入棧操作

入棧操作又叫壓棧操作瘦麸,就是向棧中存放數(shù)據(jù)谁撼。
入棧操作要在棧頂進(jìn)行,每次向棧中壓入一個(gè)數(shù)據(jù),top指針就要+1厉碟,直到棧滿(mǎn)為止

Status Push(SqStack *s,ElemType e){
    //如果空間不夠喊巍,要?jiǎng)討B(tài)追加空間
    if (s->top - s->base >= s->stackSize) {
        s->base = (ElemType *)realloc(s->base, sizeof(ElemType)*(s->stackSize + STACKINCREMENT));
        if (!s->base) {
            return ERROR;
        }
        s->top = s->base + s->stackSize;
        s->stackSize = s->stackSize + STACKINCREMENT;
    }
    //壓入值
    *(s->top) = e;
    //移動(dòng)棧頂指針
    s->top++;
    return OK;
}

(4)出棧操作

出棧操作就是在棧頂取出數(shù)據(jù),棧頂指針隨之下移的操作箍鼓。
每當(dāng)從棧內(nèi)彈出一個(gè)數(shù)據(jù)崭参,棧的當(dāng)前容量就-1

Status Pop(SqStack *s,ElemType *e){
    if (s->base == s->top) {
        //空棧直接返回
        return ERROR;
    }
    //先棧頂下移一位后再取值才是正確的
    *e = *(--s->top);
    return OK;
}
(5)清空一個(gè)棧

所謂清空一個(gè)棧,就是將棧中的元素全部作廢款咖,但棧本身物理空間并不發(fā)生改變(不是銷(xiāo)毀)何暮。
因此我們只要將s->top的內(nèi)容賦值為s->base即可,這樣s->base等于s->top铐殃,也就表明這個(gè)棧是空的了海洼。這個(gè)原理跟高級(jí)格式化只是但單純地清空文件列表而沒(méi)有覆蓋硬盤(pán)的原理是一樣的。

void clearStack(SqStack *s){
    s->top = s->base;
}
(6)銷(xiāo)毀一個(gè)棧

銷(xiāo)毀一個(gè)棧與清空一個(gè)棧不同富腊,銷(xiāo)毀一個(gè)棧是要釋放掉該棧所占據(jù)的物理內(nèi)存空間

void DestroyStack(SqStack *s){
    int length = s->stackSize;
    for (int i = 0; i < length; i++) {
        //循環(huán)將所有內(nèi)存都釋放
        free(s->base++);
    }
    //將指針都置為空
    s->base = s->top = NULL;
    s->stackSize = 0;
}
(7)計(jì)算一個(gè)棧的當(dāng)前容量

計(jì)算棧的當(dāng)前容量也就是計(jì)算棧中元素的個(gè)數(shù)坏逢,因此只要返回s.top-s.base即可。
注意赘被,棧的最大容量是指該棧占據(jù)內(nèi)存空間的大小是整,其值是s.stackSize,它與棧的當(dāng)前容量不是一個(gè)概念哦民假。

int stackLenth(SqStack s){
    //同類(lèi)型指針的相加減就是它們之間所隔的此類(lèi)元素的個(gè)數(shù)
    return (int)(s.top - s.base);
}

4.棧的鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu)

通常我們用的都是棧的順序存儲(chǔ)結(jié)構(gòu)存儲(chǔ)浮入,鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu)只作為一個(gè)知識(shí)點(diǎn),有所了解就好羊异。
棧的鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu)舵盈,簡(jiǎn)稱(chēng)棧鏈。
棧因?yàn)橹皇菞m攣?lái)做插入和刪除操作球化,所以比較好的方法就是將棧頂放在單鏈表的頭部,棧頂指針和單鏈表的頭指針合二為一瓦糟。


棧的鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu)
(1)定義
typedef struct StackNode{
    ElemType data;//存放棧的數(shù)據(jù)
    struct StackNode *next;
}StackNode,*LinkStackPtr;

typedef struct LinkStack{
    LinkStackPtr top;//top指針
    int count;//棧元素計(jì)數(shù)器
}LinkStack;
(2)進(jìn)棧操作

對(duì)于棧鏈的Push操作筒愚,假設(shè)元素值為e的新結(jié)點(diǎn)是s,top為棧頂指針菩浙,我們得到如下代碼:

Status Push(LinkStack *s,ElemType e){
    LinkStackPtr p = (LinkStackPtr)malloc(sizeof(StackNode));
    if (!p) {
        return ERROR;
    }
    p->data = e;
    p->next = s->top;
    s->top = p;
    s->count++;
    
    return OK;
}
(3)出棧操作

對(duì)于鏈棧的出棧Pop操作巢掺,假設(shè)變量P用來(lái)存儲(chǔ)要?jiǎng)h除的棧頂結(jié)點(diǎn),將棧頂指針下移一位劲蜻,最后釋放p即可

Status Pop(LinkStack *s,ElemType *e){
    if (s->count == 0 ) {
        return ERROR;
    }
    LinkStackPtr p = s->top;
    *e = p->data;
    s->top = p->next;
    free(p);
    s->count--;
    return OK;
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末陆淀,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子先嬉,更是在濱河造成了極大的恐慌轧苫,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,723評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件疫蔓,死亡現(xiàn)場(chǎng)離奇詭異含懊,居然都是意外死亡身冬,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,485評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門(mén)岔乔,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)酥筝,“玉大人,你說(shuō)我怎么就攤上這事雏门『俑瑁” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 152,998評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵茁影,是天一觀(guān)的道長(zhǎng)宙帝。 經(jīng)常有香客問(wèn)我,道長(zhǎng)呼胚,這世上最難降的妖魔是什么茄唐? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,323評(píng)論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮蝇更,結(jié)果婚禮上沪编,老公的妹妹穿的比我還像新娘。我一直安慰自己年扩,他們只是感情好蚁廓,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,355評(píng)論 5 374
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著厨幻,像睡著了一般相嵌。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上况脆,一...
    開(kāi)封第一講書(shū)人閱讀 49,079評(píng)論 1 285
  • 那天饭宾,我揣著相機(jī)與錄音,去河邊找鬼格了。 笑死看铆,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的盛末。 我是一名探鬼主播弹惦,決...
    沈念sama閱讀 38,389評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼悄但!你這毒婦竟也來(lái)了棠隐?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 37,019評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤檐嚣,失蹤者是張志新(化名)和其女友劉穎助泽,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,519評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡报咳,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,971評(píng)論 2 325
  • 正文 我和宋清朗相戀三年侠讯,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片暑刃。...
    茶點(diǎn)故事閱讀 38,100評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡厢漩,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出岩臣,到底是詐尸還是另有隱情溜嗜,我是刑警寧澤,帶...
    沈念sama閱讀 33,738評(píng)論 4 324
  • 正文 年R本政府宣布架谎,位于F島的核電站炸宵,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏谷扣。R本人自食惡果不足惜土全,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,293評(píng)論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望会涎。 院中可真熱鬧裹匙,春花似錦、人聲如沸末秃。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,289評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)练慕。三九已至惰匙,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間铃将,已是汗流浹背项鬼。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,517評(píng)論 1 262
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留劲阎,地道東北人秃臣。 一個(gè)月前我還...
    沈念sama閱讀 45,547評(píng)論 2 354
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像哪工,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子弧哎,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,834評(píng)論 2 345