數(shù)據(jù)結(jié)構(gòu)與算法基礎(chǔ)三:棧與隊列

一:棧

棧就是限定在尾部進行插入和刪除的線性表.
這種后入先出的結(jié)構(gòu)叫做Last in first out,LIFO結(jié)構(gòu);
線性表的特性椀吞玻基本都有,不過插入和刪除需要特殊處理,入棧叫做push,出棧叫做pop.棧的應(yīng)用極其廣泛,凡是能夠回退的場景,都可以用棧實現(xiàn),比如網(wǎng)頁.

棧的基本操作

1.順序結(jié)構(gòu)
順序存儲的棧,叫做順序棧.

定義一個棧

入棧

出棧

顯然入棧和出棧都是O(1)的.

順序棧,有一種獨特的使用方法,共用數(shù)組空間;
順序存儲的線性表需要一個數(shù)組來存儲,數(shù)組的長度需要事先申請,這些空間是可以利用起來的;
有這樣一種常見,當(dāng)A占用空間增加時,B一定會減少,這種此漲彼伏的場景可以用兩個棧共用數(shù)組來實現(xiàn).
將棧A的棧底設(shè)置在數(shù)組的第一個元素,將棧B的棧底設(shè)置在數(shù)組的最后一個元素.入棧時,兩邊向中間靠攏.


image.png

2.鏈式存儲
鏈式存儲叫做鏈棧,這種結(jié)構(gòu)就很舒服了,既然棧是后進先出,那么直接把頭指針放在棧頂就ok了.
鏈棧和鏈表一樣,只是插入和刪除需要特殊操作.

上面是節(jié)點,下面是棧

插入,也就是入棧,把新節(jié)點的next指向top,再移動top即可.


插入

刪除,就是出棧,把top往下移動一位,然后講棧頂節(jié)點釋放.


image.png

遞歸調(diào)用函數(shù)是一種典型的棧結(jié)構(gòu):
當(dāng)調(diào)用嵌套調(diào)用函數(shù)式,函數(shù)體和參數(shù)就會入棧,當(dāng)達到設(shè)置的條件時,就開始出棧


斐波那契數(shù)列是后兩項等于前兩項之和,1,1,2,3,5,8...

二:隊列

對比棧,隊列就是只準在一端插入,在另一端刪除的線性表
隊列是先進先出的,first in first out,簡稱FIFO.
只許進的(插入)叫隊尾,只許出的(刪除)叫隊頭;

1.順序存儲
順序結(jié)構(gòu)的線性表存在一個數(shù)組里.叫做順序隊列.
當(dāng)刪除隊頭元素時,后面的元素需要向前移動一位,以保證元素一直存儲在數(shù)組前n個;
當(dāng)然也可以不移動,這樣的話就相當(dāng)于隊頭移動了;
定義一個front指針指向隊頭,定義一個rear指向隊尾后后面一個下標(biāo)的位置;當(dāng)front = rear時,這就是個空隊列.

隊列

但是前面會空出來,當(dāng)隊尾到達數(shù)組最大時,叫做假溢出.
假溢出

如果到達隊尾時再從頭開始,就可以解決假溢出,叫做循環(huán)隊列,注意它是順序結(jié)構(gòu)的,不是鏈式.
如此,當(dāng)數(shù)組最后一位被使用的時候,rear移動到了數(shù)組第0的位置,但是這樣一來,就沒法判斷隊列是空還是滿了


rear=front

解決辦法是空出一個,然后根據(jù)一定的關(guān)系來判斷,就是(rear+1) % queueSize = front;當(dāng)滿足這個條件時,數(shù)組已滿.

2.鏈式存儲
鏈式存儲的隊列,叫做鏈隊列,本質(zhì)是個單向鏈表,多了一個rear指針,只能隊頭刪除,隊尾插入

鏈隊列

空的鏈隊列

  • 入隊操作
    就是在隊尾插入節(jié)點,然后修改rear指針


    入隊
  • 出隊操作
    出隊就是刪除第一個節(jié)點,然后修改front指針


    出棧
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末做葵,一起剝皮案震驚了整個濱河市播演,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌板惑,老刑警劉巖望几,帶你破解...
    沈念sama閱讀 219,427評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異刘莹,居然都是意外死亡,警方通過查閱死者的電腦和手機焚刚,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,551評論 3 395
  • 文/潘曉璐 我一進店門点弯,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人矿咕,你說我怎么就攤上這事抢肛。” “怎么了碳柱?”我有些...
    開封第一講書人閱讀 165,747評論 0 356
  • 文/不壞的土叔 我叫張陵捡絮,是天一觀的道長。 經(jīng)常有香客問我莲镣,道長福稳,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,939評論 1 295
  • 正文 為了忘掉前任瑞侮,我火速辦了婚禮的圆,結(jié)果婚禮上鼓拧,老公的妹妹穿的比我還像新娘。我一直安慰自己略板,他們只是感情好毁枯,可當(dāng)我...
    茶點故事閱讀 67,955評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著叮称,像睡著了一般。 火紅的嫁衣襯著肌膚如雪藐鹤。 梳的紋絲不亂的頭發(fā)上瓤檐,一...
    開封第一講書人閱讀 51,737評論 1 305
  • 那天,我揣著相機與錄音娱节,去河邊找鬼挠蛉。 笑死,一個胖子當(dāng)著我的面吹牛肄满,可吹牛的內(nèi)容都是我干的谴古。 我是一名探鬼主播,決...
    沈念sama閱讀 40,448評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼稠歉,長吁一口氣:“原來是場噩夢啊……” “哼掰担!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起怒炸,我...
    開封第一講書人閱讀 39,352評論 0 276
  • 序言:老撾萬榮一對情侶失蹤带饱,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后阅羹,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體勺疼,經(jīng)...
    沈念sama閱讀 45,834評論 1 317
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,992評論 3 338
  • 正文 我和宋清朗相戀三年捏鱼,在試婚紗的時候發(fā)現(xiàn)自己被綠了执庐。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,133評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡导梆,死狀恐怖轨淌,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情问潭,我是刑警寧澤猿诸,帶...
    沈念sama閱讀 35,815評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站狡忙,受9級特大地震影響梳虽,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜灾茁,卻給世界環(huán)境...
    茶點故事閱讀 41,477評論 3 331
  • 文/蒙蒙 一窜觉、第九天 我趴在偏房一處隱蔽的房頂上張望谷炸。 院中可真熱鬧,春花似錦禀挫、人聲如沸旬陡。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,022評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽描孟。三九已至,卻和暖如春砰左,著一層夾襖步出監(jiān)牢的瞬間匿醒,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,147評論 1 272
  • 我被黑心中介騙來泰國打工缠导, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留廉羔,地道東北人。 一個月前我還...
    沈念sama閱讀 48,398評論 3 373
  • 正文 我出身青樓僻造,卻偏偏與公主長得像憋他,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子髓削,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,077評論 2 355

推薦閱讀更多精彩內(nèi)容