国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

詳解python數據結構之棧stack

瀏覽:79日期:2022-06-20 11:56:22
前言

棧(Stack)是一種運算受限的線性表。

按照先進后出(FILO,First In Last Out)的原則存儲數據,先進入的數據被壓入棧底,最后的數據在棧頂。棧只能在一端進行插入和刪除操作。

文章內容包含:

(1)棧的基本格式(2)壓棧 push_stack(3)出棧 pop_stack(4)取棧頂 peek_stack

一、棧的基本格式

class Stack(): def __init__ (self,size):self.size = size #棧空間大小self.top = -1 #棧中進入一個數據 top 加 1self.stack = [] def display_stack(self):#棧stack的打印print(self.stack)if __name__ == '__main__': stack = Stack(5) #設定棧空間 stack.display_stack() #打印棧數據二、進棧與壓棧 push_stack

class Stack(): def __init__ (self,size):self.size = sizeself.top = -1self.stack = [] #進棧數據列表 def display_stack(self):print(self.stack) def push_stack(self,data):if len(self.stack ) >= self.size: #當數據數量大于設置的空間,則棧溢出 print('stack over flow!') returnself.stack.append(data) #沒有棧溢出就將數據追加到列表中self.top += 1 #棧中每增加一個數據就加 1if __name__ == '__main__': stack = Stack(5) stack.push_stack(0) stack.push_stack(1) stack.push_stack(2) stack.push_stack(3) stack.push_stack(4) stack.push_stack(5) #stack空間是 5,這里進棧數據時 6 個,即提示棧溢出stack over flow! stack.display_stack()

執行結果:

詳解python數據結構之棧stack

三、出棧 pop_stack

class Stack(): def __init__ (self,size):self.size = sizeself.top = -1self.stack = [] #進棧數據列表 def display_stack(self):print(self.stack) def push_stack(self,data):if len(self.stack ) >= self.size: print('stack over flow!') returnself.stack.append(data)self.top += 1 def pop_stack(self):if self.top <= -1: #當top小于等于初始值 -1 時說明stack數據列表為空 print('stack is empty!') returnret = self.stack.pop() #stack數據列表不為空就取出最后進的值,列表數據數量就少一個self.top -= 1 return retif __name__ == '__main__': stack = Stack(5) stack.push_stack(0) stack.push_stack(1) stack.push_stack(2) stack.push_stack(3) stack.push_stack(4) stack.display_stack() #進棧數據有 5 個,出棧函數調用了 6 次,就出現了提示stack is empty! ret = stack.pop_stack() print(ret) stack.display_stack() ret = stack.pop_stack() print(ret) stack.display_stack() ret = stack.pop_stack() print(ret) stack.display_stack() ret = stack.pop_stack() print(ret) stack.display_stack() ret = stack.pop_stack() print(ret) stack.display_stack() ret = stack.pop_stack() print(ret) stack.display_stack()

執行結果:

詳解python數據結構之棧stack

四、取棧頂 peek_stack

class Stack(): def __init__ (self,size):self.size = sizeself.top = -1self.stack = [] def display_stack(self):print(self.stack) def push_stack(self,data):if len(self.stack ) >= self.size: print('stack over flow!') returnself.stack.append(data) self.top += 1 def peek_stack(self):if self.top == -1: #當棧內沒有數據時 提示 stack is empty! print('stack is empty!') returnpeek = self.stack[self.top] #棧不為空時,將棧頂的數據提取出來return peekif __name__ == '__main__': stack = Stack(5) stack.push_stack(0) stack.push_stack(1) stack.push_stack(2) stack.push_stack(3) stack.push_stack(4) stack.push_stack(5) stack.display_stack() peek = stack.peek_stack() print(peek)

執行結果:

詳解python數據結構之棧stack

到此這篇關于詳解python數據結構之棧stack的文章就介紹到這了,更多相關python 棧stack內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 国产一区二区三区四区在线 | 欧美日韩一区二区三区在线观看 | 我们2018在线完整免费观看 | 亚洲精品在线观看视频 | 成人毛片手机版免费看 | 亚洲精品一级一区二区三区 | 三级精品在线观看 | 国产成人综合高清在线观看 | 久久久久一区二区三区 | 欧美精品人爱a欧美精品 | 成人a一级毛片免费看 | 国产成人精品亚洲一区 | 国产成人久久精品二区三区牛 | videos欧美丰满肥婆 | 欧美三级中文字幕 | 亚洲精品综合欧美一区二区三区 | 国产成人精品福利站 | 国产精品久久人人做人人爽 | 免费毛片视频网站 | 亚洲另类激情综合偷自拍图 | 久久精品中文字幕一区 | 亚洲欧美一区二区久久 | 在线看片欧美 | 亚洲综合色一区二区三区另类 | 男女视频在线看 | 亚洲三级中文字幕 | 一区中文字幕 | 成人精品一区久久久久 | 欧美一级专区免费大片 | 国内国外精品一区二区 | 韩国欧洲一级毛片免费 | 午夜在线精品不卡国产 | 欧美日韩亚洲v在线观看 | 成人免费观看www在线 | 亚洲va中文字幕欧美不卡 | 亚洲特级毛片 | 国产精品亚洲午夜不卡 | 毛片免费观看的视频在线 | 国产日韩欧美亚洲 | 日韩欧美综合在线二区三区 | 天天干亚洲 |