python-030-實(shí)現(xiàn)棧結(jié)構(gòu)-用數(shù)組-適配器設(shè)計(jì)模式

棧是最簡(jiǎn)單的數(shù)據(jù)結(jié)構(gòu)剑肯,但也是最重要的數(shù)據(jù)結(jié)構(gòu)。它出現(xiàn)在很多不同的應(yīng)用中欺旧,在更復(fù)雜的數(shù)據(jù)結(jié)構(gòu)和算法中充當(dāng)工具姑丑。
從形式上,棧支持兩種操作的抽象數(shù)據(jù)類(lèi)型ADT辞友,壓棧和入棧:

  • S.push()
  • S.pop()
    此外栅哀,他還有以下方法:
  • S.top() 在不移除棧頂元素的前提下,返回棧頂元素踏枣,若棧為空昌屉,則報(bào)錯(cuò)。
  • S.is_empty() 如果棧中沒(méi)有元素茵瀑,返回True间驮。
  • S.is_empty() 返回棧中元素的個(gè)數(shù)。
    初始化棧時(shí)马昨,棧一半為空竞帽,且容量沒(méi)有限制,棧元素可以是任意類(lèi)型鸿捧。

棧是一種先進(jìn)后出的數(shù)據(jù)結(jié)構(gòu)(Last In First Out)——LIFO屹篓。可以聯(lián)想到python的列表匙奴,list.append()堆巧、list.pop(),是現(xiàn)成的方法泼菌〉簦可以直接用。
有了以上信息哗伯,我們就可以開(kāi)始著手實(shí)現(xiàn)一個(gè)棧類(lèi)了荒揣。

這里涉及到一種設(shè)計(jì)模式——適配器模式。python的list類(lèi)可以很方便的實(shí)現(xiàn)棧焊刹,所以我們通過(guò)改編它來(lái)實(shí)現(xiàn)系任。

適配器設(shè)計(jì)模式適用于任何上下文,可以使我們可以有效地使用一個(gè)現(xiàn)有的類(lèi)虐块,以使它的方法能夠與那些與其相關(guān)但又不同的類(lèi)或者接口相匹配俩滥。
通用的使用方法是將一個(gè)包含現(xiàn)存類(lèi)作為一個(gè)新類(lèi)的隱藏域,利用這個(gè)隱藏實(shí)例變量的方法實(shí)現(xiàn)新類(lèi)的方法非凌。
以這種方式應(yīng)用適配器設(shè)計(jì)模式举农,我們已經(jīng)創(chuàng)建了一個(gè)新類(lèi),可以執(zhí)行一些現(xiàn)有類(lèi)相同的方法敞嗡,但是卻用更加方便的方式進(jìn)行封裝颁糟。

改編列表類(lèi):

  • S.push(e) -------------->L.append(e)
  • S.pop(e) -------------->L.pop(e)
  • S.top() -------------->L[-1]
  • S.is_empty() -------------->len(L)==0
  • len(S) -------------->len(L)

我們先定義一個(gè)異常類(lèi)用來(lái)說(shuō)明棧中為空。

class Empty(Exception):
    """Error attempting to access an empty container"""
    pass

下面是棧類(lèi)的代碼:

class Empty(Exception):
    """Error attempting to access an empty container"""
    pass


class ArrayStack:
    """LIFO Stack using a python list"""
    def __init__(self):
        self._data = []

    def __len__(self):
        """返回棧中的元素個(gè)數(shù)"""
        return len(self._data)

    def is_empty(self):
        """如果棧為空喉悴,返回True"""
        return len(self._data) == 0

    def push(self, e):
        """壓棧"""
        return self._data.append(e)

    def top(self):
        """返回棧頂元素棱貌,但不返回不彈棧"""
        if self.is_empty():
            raise Empty('Stack is empty!')
        return self._data[-1]

    def pop(self):
        """彈出棧頂元素,并返回這個(gè)元素"""
        if self.is_empty():
            raise Empty('Stack is empty!')
        return self._data.pop()

    def __str__(self):
        return str(self._data)


if __name__ == '__main__':
    # 調(diào)用這個(gè)棧
    s = ArrayStack()
    s.push(1)
    s.push(2)
    s.push(3)
    print(s)
    print('len(s)', len(s))
    print('s.top()',s.top())
    s.pop()
    print(s)
    print('s.pop()',s.pop())
    print('len(s)', len(s))
    s.push(5)
    s.push(9)
    print(s)
    print('len(s)', len(s))

我在最下面又加了str()方法箕肃,可以打印棧婚脱,可以方便我們做測(cè)試。

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

image.png
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末勺像,一起剝皮案震驚了整個(gè)濱河市障贸,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌吟宦,老刑警劉巖篮洁,帶你破解...
    沈念sama閱讀 221,576評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異殃姓,居然都是意外死亡袁波,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,515評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門(mén)蜗侈,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)篷牌,“玉大人,你說(shuō)我怎么就攤上這事踏幻〖霞眨” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 168,017評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵该面,是天一觀(guān)的道長(zhǎng)夭苗。 經(jīng)常有香客問(wèn)我,道長(zhǎng)吆倦,這世上最難降的妖魔是什么听诸? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 59,626評(píng)論 1 296
  • 正文 為了忘掉前任,我火速辦了婚禮蚕泽,結(jié)果婚禮上晌梨,老公的妹妹穿的比我還像新娘。我一直安慰自己须妻,他們只是感情好仔蝌,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,625評(píng)論 6 397
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著荒吏,像睡著了一般敛惊。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上绰更,一...
    開(kāi)封第一講書(shū)人閱讀 52,255評(píng)論 1 308
  • 那天瞧挤,我揣著相機(jī)與錄音锡宋,去河邊找鬼。 笑死特恬,一個(gè)胖子當(dāng)著我的面吹牛执俩,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播癌刽,決...
    沈念sama閱讀 40,825評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼役首,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了显拜?” 一聲冷哼從身側(cè)響起衡奥,我...
    開(kāi)封第一講書(shū)人閱讀 39,729評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎远荠,沒(méi)想到半個(gè)月后矮固,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,271評(píng)論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡矮台,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,363評(píng)論 3 340
  • 正文 我和宋清朗相戀三年乏屯,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片瘦赫。...
    茶點(diǎn)故事閱讀 40,498評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡辰晕,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出确虱,到底是詐尸還是另有隱情含友,我是刑警寧澤,帶...
    沈念sama閱讀 36,183評(píng)論 5 350
  • 正文 年R本政府宣布校辩,位于F島的核電站窘问,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏宜咒。R本人自食惡果不足惜惠赫,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,867評(píng)論 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望故黑。 院中可真熱鬧儿咱,春花似錦、人聲如沸场晶。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,338評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)诗轻。三九已至钳宪,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背吏颖。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,458評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工搔体, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人侦高。 一個(gè)月前我還...
    沈念sama閱讀 48,906評(píng)論 3 376
  • 正文 我出身青樓嫉柴,卻偏偏與公主長(zhǎng)得像厌杜,于是被迫代替她去往敵國(guó)和親奉呛。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,507評(píng)論 2 359

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