python棧的基本定義與使用方法示例【初始化、賦值、入棧、出棧等】
本文實(shí)例講述了python棧的基本定義與使用方法。分享給大家供大家參考,具體如下:
# -*- coding:utf-8 -*- #! python3 #在桟的設(shè)計(jì)中,我們需要定義一個實(shí)例屬性top。三個實(shí)例方法:獲取棧頂元素peek();出桟pop();入棧push() #棧的效果:先進(jìn)后出 class Node(object): ##節(jié)點(diǎn),包括兩個屬性,一個是節(jié)點(diǎn)的值,一個是節(jié)點(diǎn)的下一個指向 def __init__(self,value): self.value = value #賦值給節(jié)點(diǎn) self.next = None #節(jié)點(diǎn)的下一個指向 class stack(object): def __init__(self): self.top = None #創(chuàng)建棧,賦予top棧頂屬性,top初始為空 def peek(self): #獲取棧頂?shù)脑?,返回對?yīng)的值 if self.top!= None: #如果棧頂不為空,也就是說棧里有數(shù)據(jù) return self.top.value #那就直接返回棧頂?shù)闹? else: return None #如果棧里無數(shù)據(jù),則返回None def push(self,node): #添加元素到棧(參數(shù)包括self和節(jié)點(diǎn)的value,node) if node != None: #如果加入的節(jié)點(diǎn),不為空 packNode = Node(node) #實(shí)例化Node類 packNode.next = self.top #將新增的節(jié)點(diǎn)的指向賦值為棧頂?shù)闹赶? self.top = packNode #將棧頂?shù)墓?jié)點(diǎn),賦值為新增節(jié)點(diǎn) return packNode.value #返回節(jié)點(diǎn)的值 else: return None #返回None def pop(self): #出棧 if self.top == None: #如果棧是空的 return None #返回None else: tmp = self.top.value #將棧頂?shù)闹祩鹘otmp self.top = self.top.next #將棧頂指向變?yōu)槟壳皸m數(shù)南乱粋€節(jié)點(diǎn) return tmp #返回出棧的節(jié)點(diǎn)的值 s = stack() a = Node(1) print(s.push(a).value) print(s.push(2)) print(s.push(3)) print(s.peek()) print(s.push(4)) print(s.pop()) print(s.pop()) print(s.pop()) print(s.pop().value)
運(yùn)行結(jié)果:
1
2
3
3
4
4
3
2
1
更多關(guān)于Python相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python加密解密算法與技巧總結(jié)》、《Python編碼操作技巧總結(jié)》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》及《Python入門與進(jìn)階經(jīng)典教程》
希望本文所述對大家Python程序設(shè)計(jì)有所幫助。
- Python算術(shù)運(yùn)算符實(shí)例詳解
- Python3單行定義多個變量或賦值方法
- python 解決動態(tài)的定義變量名,并給其賦值的方法(大數(shù)據(jù)處理)
- python 隊(duì)列基本定義與使用方法【初始化、賦值、判斷等】
- python入門教程之基本算術(shù)運(yùn)算符
- Python Spyder 調(diào)出縮進(jìn)對齊線的操作
- python 實(shí)現(xiàn)循環(huán)定義、賦值多個變量的操作
- Python?if?else語句對縮進(jìn)的要求
- python小例子-縮進(jìn)式編碼+算術(shù)運(yùn)算符+定義與賦值
相關(guān)文章
詳解Python 實(shí)現(xiàn) ZeroMQ 的三種基本工作模式
ZMQ是一個簡單好用的傳輸層,像框架一樣的一個 socket library,他使得 Socket 編程更加簡單、簡潔和性能更高。 ,這篇文章主要介紹了Python 實(shí)現(xiàn) ZeroMQ 的三種基本工作模式,需要的朋友可以參考下2020-03-03
OpenCV指紋識別實(shí)現(xiàn)代碼實(shí)例
使用OpenCV進(jìn)行指紋識別涵蓋特征提取與匹配,通過SIFT和FLANN實(shí)現(xiàn)匹配點(diǎn)計(jì)算,進(jìn)而識別指紋ID和姓名,盡管OpenCV具備強(qiáng)大的圖像處理功能,指紋識別依舊面臨挑戰(zhàn),需要的朋友可以參考下2024-10-10
初學(xué)python的操作難點(diǎn)總結(jié)(新手必看篇)
下面小編就為大家?guī)硪黄鯇W(xué)python的操作難點(diǎn)總結(jié)(新手必看篇)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-08-08
Python使用gRPC實(shí)現(xiàn)數(shù)據(jù)分析能力的共享
gRPC是一個高性能、開源、通用的遠(yuǎn)程過程調(diào)用(RPC)框架,由Google推出,本文主要介紹了Python如何使用gRPC實(shí)現(xiàn)數(shù)據(jù)分析能力的共享,感興趣的可以了解下2024-02-02
Django自定義分頁與bootstrap分頁結(jié)合
這篇文章主要為大家詳細(xì)介紹了Django自定義分頁與bootstrap分頁結(jié)合使用的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-05-05
AI:如何訓(xùn)練機(jī)器學(xué)習(xí)的模型
這篇文章主要介紹了是如何進(jìn)行機(jī)器學(xué)習(xí)的模型的訓(xùn)練,全文邏輯清晰,簡單易懂,如果您正在學(xué)習(xí)機(jī)器學(xué)習(xí)那么可以參考下,說不定會有不一樣的收貨2021-04-04
Python 支付整合開發(fā)包的實(shí)現(xiàn)
這篇文章主要介紹了Python 支付整合開發(fā)包的實(shí)現(xiàn),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-01-01

