Python中棧的詳細介紹
本文轉(zhuǎn)自公眾號:"算法與編程之美"
1、問題描述
Python
中數(shù)據(jù)類型有列表,元組,字典,隊列,棧,樹等等。像列表,元組這樣的都是python內(nèi)置數(shù)據(jù)結(jié)構(gòu);棧,隊列這些都是需要我們自己去定義的。
棧是一種只允許在一端插入和取出的數(shù)據(jù)結(jié)構(gòu),這一端通常被叫做棧頂,另一端叫棧底,沒有數(shù)據(jù)的叫空棧。這種數(shù)據(jù)類型由于是我們自己進行定義,所以有很多功能都需要自己寫出相應函數(shù)來實現(xiàn)。所以我們看看這里的功能。
2、解決方案
棧的基本操作大概有:生成棧,入棧,出棧,返回棧頂元素,判斷是否為空棧,返回棧內(nèi)元素個數(shù)。
首先我們先要創(chuàng)建一個棧:
class stack(object): def __init__(self): self.__list = []
這里創(chuàng)建出來就是一個空棧,想要檢測的話我們也可以通過一個函數(shù)來檢測是否為空棧:
def is_empty(self): return self.__list == [] # return not self.__list
這是兩種return
的檢測方式,任選其一都能夠完成。
接下來創(chuàng)建了棧,也知道了檢測棧是否為空。如定義所說,因為棧是我們自己定義的一種數(shù)據(jù)結(jié)構(gòu),且滿足一個后進先出的規(guī)則,那么元素的保存和取出也自然不同。我們叫做入棧和出棧。首先是入棧,我么僅需要定義一個push函數(shù):
def push(self,item): self.__list.append(item)
然后定義一個函數(shù)pop來進行出棧:
def pop(self): self.__list.pop()
peek函數(shù)進行返回棧頂元素操作:
def peek(self): if self.__list: return self.__list[-1] else: return None
size函數(shù)進行返回棧的元素個數(shù)的操作:
def size(self): return len(self.__list)
3、結(jié)語
以上便是棧這種數(shù)據(jù)結(jié)構(gòu)的大概用法,通過定義各種函數(shù),然后在使用時直接調(diào)用,這樣也顯得非常的方便。
定義棧的函數(shù)時,特別要注意的是里面關(guān)鍵詞的使用,例如__list,__init__,
中的下劃線的使用,這些都是系統(tǒng)內(nèi)定的,不能輕易改變,不然很容易讓系統(tǒng)報錯。
到此這篇關(guān)于Python
中棧的詳細介紹的文章就介紹到這了,更多相關(guān)Python
中的棧內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python 讀取xml數(shù)據(jù),cv2裁剪圖片實例
這篇文章主要介紹了Python 讀取xml數(shù)據(jù),cv2裁剪圖片實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-03-03使用python socket分發(fā)大文件的實現(xiàn)方法
今天小編就為大家分享一篇使用python socket分發(fā)大文件的實現(xiàn)方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-07-07基于python實現(xiàn)MQTT發(fā)布訂閱過程原理解析
這篇文章主要介紹了基于python實現(xiàn)MQTT發(fā)布訂閱過程原理解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-07-07使用優(yōu)化器來提升Python程序的執(zhí)行效率的教程
這篇文章主要介紹了使用優(yōu)化器來提升Python程序的執(zhí)行效率的教程,包括編寫計時器和使用內(nèi)建的優(yōu)化器等,需要的朋友可以參考下2015-04-04