Python實現(xiàn)的棧(Stack)
前言
Python本身已有順序表(List、Tupple)的實現(xiàn),所以這里從棧開始。
什么是棧
想象一摞被堆起來的書,這就是棧。這堆書的特點是,最后被堆進(jìn)去的書,永遠(yuǎn)在最上面。從這堆書里面取一本書出來,取哪本書最方便?肯定是最上面那本。棧這種數(shù)據(jù)結(jié)構(gòu)的特點就是如此:后進(jìn)先出(Last In First Out - LIFO),即最后被堆進(jìn)去的數(shù)據(jù),最先被拿出來。
棧的Python實現(xiàn)
??梢杂庙樞虮矸绞綄崿F(xiàn),也可以用鏈表方式實現(xiàn)。我大Python的內(nèi)建數(shù)據(jù)結(jié)構(gòu)太強大,可以用list直接實現(xiàn)棧,簡單快捷。人生苦短,我用Python。代碼如下:
class Stack(object): # 初始化棧為空列表 def __init__(self): self.items = [] # 判斷棧是否為空,返回布爾值 def is_empty(self): return self.items == [] # 返回棧頂元素 def peek(self): return self.items[len(self.items) - 1] # 返回棧的大小 def size(self): return len(self.items) # 把新的元素堆進(jìn)棧里面(程序員喜歡把這個過程叫做壓棧,入棧,進(jìn)棧……) def push(self, item): self.items.append(item) # 把棧頂元素丟出去(程序員喜歡把這個過程叫做出?!? def pop(self, item): return self.items.pop() if __name__ == __main__: # 初始化一個棧對象 my_stack = Stack() # 把'h'丟進(jìn)棧里 my_stack.push('h') # 把'a'丟進(jìn)棧里 my_stack.push('a') # 看一下棧的大?。ㄓ袔讉€元素) print my_stack.size() # 打印棧頂元素 print my_stack.peek() # 把棧頂元素丟出去,并打印出來 print my_stack.pop() # 再看一下棧頂元素是誰 print my_stack.peek() # 這個時候棧的大小是多少? print my_stack.size() # 再丟一個棧頂元素 print my_stack.pop() # 看一下棧的大小 print my_stack.size # 棧是不是空了? print my_stack.is_empty() # 哇~真好吃~ print 'Yummy~'
Tips:
看完上面的代碼,聰明的同學(xué)一定知道了,Python里面實現(xiàn)棧,就是把list包裝成一個類,再添加一些方法作為棧的基本操作。其他的數(shù)據(jù)結(jié)構(gòu)在Python中也是以類似的方式實現(xiàn)的。
那么,這里有一些有的沒的要說一下~
如果希望items[]是Stack類私有的屬性,這樣做就好了:
def __init__(self): self.__items = []
沒錯,就是在items前面加兩個下劃線__,在Python中,類的私有成員就是這樣定義噠~
如果希望限定Stack類的成員只有items,不要其他的怪蜀黍亂加成員,那么這樣做就好了:
class Stack(object): __slots__ = ('__items') def __init__(self): self.__items = []
這樣就安全多啦~
Python并沒有Java里的public/private/protected
這樣的修飾符,因為Python的設(shè)計者認(rèn)為,“大家都是成年人了”~
總結(jié)
以上所述是小編給大家介紹的Python實現(xiàn)的棧(Stack),希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
- Python pandas軸旋轉(zhuǎn)stack和unstack的使用說明
- python GUI庫圖形界面開發(fā)之PyQt5窗口布局控件QStackedWidget詳細(xì)使用方法
- Python numpy實現(xiàn)數(shù)組合并實例(vstack,hstack)
- python django使用haystack:全文檢索的框架(實例講解)
- Python中使用haystack實現(xiàn)django全文檢索搜索引擎功能
- 通過Python使用saltstack生成服務(wù)器資產(chǎn)清單
- Python算法之棧(stack)的實現(xiàn)
- 詳解python數(shù)據(jù)結(jié)構(gòu)之棧stack
相關(guān)文章
Python 聊聊socket中的listen()參數(shù)(數(shù)字)到底代表什么
本篇文章對Python 聊聊socket中的listen()參數(shù)(數(shù)字)到底代表什么,進(jìn)行了很好的講解,希望對大家有所幫助。一起跟隨小編過來看看吧2021-04-04python Selenium爬取內(nèi)容并存儲至MySQL數(shù)據(jù)庫的實現(xiàn)代碼
這篇文章主要介紹了python Selenium爬取內(nèi)容并存儲至MySQL數(shù)據(jù)庫的實現(xiàn)代碼,需要的朋友可以參考下2017-03-03python實現(xiàn)對excel中需要的數(shù)據(jù)的單元格填充顏色
這篇文章主要介紹了python實現(xiàn)對excel中需要的數(shù)據(jù)的單元格填充顏色,文章圍繞主題展開詳細(xì)單元格填充介紹,具有一定的參考價值,需要的小伙伴可以參考一下2022-06-06一行python實現(xiàn)樹形結(jié)構(gòu)的方法
今天小編就為大家分享一篇一行python實現(xiàn)樹形結(jié)構(gòu)的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-08-08Python2與Python3關(guān)于字符串編碼處理的差別總結(jié)
這篇文章主要給大家介紹了Python2與Python3關(guān)于字符串編碼處理差別的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09pythonfor循環(huán)中range與len區(qū)別
這篇文章主要介紹了pythonfor循環(huán)中range與len區(qū)別,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定參考價值,需要的小伙伴可以參考一下2022-06-06