Java基礎(chǔ)學(xué)習(xí):java數(shù)據(jù)結(jié)構(gòu)中的棧

Java基礎(chǔ)學(xué)習(xí):java數(shù)據(jù)結(jié)構(gòu)中的棧

深圳達(dá)內(nèi)教育      2022-04-07 23:00:01     2

Java基礎(chǔ)學(xué)習(xí):java數(shù)據(jù)結(jié)構(gòu)中的棧,數(shù)據(jù)結(jié)構(gòu)中的棧不要與Java中的?;煜麄儌z不是一回事,數(shù)據(jù)結(jié)構(gòu)中的棧是一種受限制的線性表,棧具有先進(jìn)后出、后進(jìn)先出的特點(diǎn)

課程價(jià)格 請咨詢

上課時(shí)段: 授課校區(qū):

詳細(xì)介紹

    數(shù)據(jù)結(jié)構(gòu)中的棧不要與Java中的棧混淆,他們倆不是一回事,數(shù)據(jù)結(jié)構(gòu)中的棧是一種受限制的線性表,棧具有先進(jìn)后出、后進(jìn)先出的特點(diǎn),因?yàn)闂V辉试S訪問最后一個(gè)數(shù)據(jù)項(xiàng),即最后插入的數(shù)據(jù)項(xiàng)。也許你會有疑問,棧既然有這么多限制,為什么不用數(shù)組或者鏈表而使用棧?在開發(fā)中,我們有特定的場景,根據(jù)特定的場景去選用數(shù)據(jù)結(jié)構(gòu),棧的適用場景非常多,比如瀏覽器的前進(jìn)與后退、字符串括號的合法性等,我們使用棧來實(shí)現(xiàn)就比較好,因?yàn)闂O鄬?shù)組、鏈表來說對外提供的接口要少很多,接口少了,出錯(cuò)的概率就減少了,對風(fēng)險(xiǎn)的可控性就提高了。

    實(shí)現(xiàn)一個(gè)棧

    從棧的定義中可以看出,棧主要有兩個(gè)操作,一個(gè)是新增一條數(shù)據(jù),我們叫做入棧,另一個(gè)是獲取一條數(shù)據(jù),稱為出棧,下面兩張圖是入棧出棧示意圖。

    棧的實(shí)現(xiàn)有兩種方式,一種是基于數(shù)組實(shí)現(xiàn)的,我們叫作順序棧,另一種是基于鏈表實(shí)現(xiàn)的,我們叫作鏈?zhǔn)綏?。下面是兩種棧的實(shí)現(xiàn)代碼

    基于數(shù)組的順序棧

    基于鏈表的鏈?zhǔn)綏?/p>

    棧的實(shí)現(xiàn)比較簡單,因?yàn)闂I婕暗牟僮鞑欢?,主要就入棧和出棧兩個(gè)操作。

    棧的應(yīng)用

    檢測字符串括號的合法性

    我們有時(shí)候需要檢測字符串括號的合法性,即一個(gè)左括號需要匹配一個(gè)右括號,這個(gè)我們可以使用棧來實(shí)現(xiàn)。我們可以從一個(gè)合法的括號來理解為什么使用棧?如果括號使用合法,最后一個(gè)左括號跟第一個(gè)右括號是匹配的,倒數(shù)第二個(gè)左括號和第二個(gè)右括號匹配的,以此類推,這符合我們棧的特性先進(jìn)后出。

    假設(shè)我們有三種括號:圓括號()、方括號[]和花括號{},我們使用棧來檢測括號的合法性。我們將左括號全部壓棧,當(dāng)出現(xiàn)右括號時(shí),我們就進(jìn)行匹配,這時(shí)候有如下三種情況:

    棧為空,說明沒有左括號,括號使用不合法

    棧中取出來的左括號跟右括號不匹配,括號使用不合法

    棧中取出的左括號跟右括號匹配,括號使用暫時(shí)合法

    當(dāng)整個(gè)字符串都掃描完成后,檢測棧中是否還有值,如果棧為空,則說明括號使用合法,反正,則括號使用不合法。

    實(shí)現(xiàn)代碼

    瀏覽器前進(jìn)、后退功能

    我們使用瀏覽器都知道,瀏覽器可以前進(jìn)、后退功能,瀏覽器的前進(jìn)后退也符合棧的特點(diǎn),我們最先訪問的網(wǎng)頁肯定要最后才能倒回去。我們一起來看看棧怎么實(shí)現(xiàn)這個(gè)功能?

    我們需要定義兩個(gè)棧,我們將首次訪問的頁面壓棧到第一個(gè)棧中,當(dāng)點(diǎn)擊后退時(shí),從第一個(gè)棧中取出數(shù)據(jù)放入到第二個(gè)棧,當(dāng)點(diǎn)擊前進(jìn)按鈕時(shí),從第二個(gè)棧取出數(shù)據(jù)放入第一個(gè)棧。當(dāng)?shù)谝粋€(gè)棧沒有數(shù)據(jù)時(shí),說明沒有頁面可以點(diǎn)擊后退了,當(dāng)?shù)诙€(gè)棧沒有數(shù)據(jù)時(shí),說明沒有頁面可以點(diǎn)擊前進(jìn)了。這樣我們就通過棧實(shí)現(xiàn)了瀏覽器前進(jìn)、后退功能。

 以上就是深圳達(dá)內(nèi)教育java培訓(xùn)機(jī)構(gòu)的小編針對“Java基礎(chǔ)學(xué)習(xí):java數(shù)據(jù)結(jié)構(gòu)中的棧”的內(nèi)容進(jìn)行的回答,希望對大家有所幫助,如有疑問,請?jiān)诰€咨詢,有專業(yè)老師隨時(shí)為你服務(wù)。

Java基礎(chǔ)學(xué)習(xí)

培訓(xùn)啦提醒您:交易時(shí)請核實(shí)對方資質(zhì),對于過大宣傳或承諾需謹(jǐn)慎!任何要求預(yù)付定金、匯款等方式均存在風(fēng)險(xiǎn),謹(jǐn)防上當(dāng)。