好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > 詳解python數據結構之棧stack

詳解python數據結構之棧stack

熱門標簽:海南400電話如何申請 白銀外呼系統 公司電話機器人 唐山智能外呼系統一般多少錢 哈爾濱ai外呼系統定制 騰訊外呼線路 廣告地圖標注app 激戰2地圖標注 陜西金融外呼系統

前言

棧(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 加 1
        self.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 = size
        self.top = -1
        self.stack = [] #進棧數據列表
    def display_stack(self):
        print(self.stack)
        
    def push_stack(self,data):
        if len(self.stack ) >= self.size: #當數據數量大于設置的空間,則棧溢出
            print("stack over flow!")
            return
        self.stack.append(data) #沒有棧溢出就將數據追加到列表中
        self.top += 1 #棧中每增加一個數據就加 1
        
if __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()

執行結果:

三、出棧 pop_stack

class Stack():
    def __init__ (self,size):
        self.size = size
        self.top = -1
        self.stack = [] #進棧數據列表
    def display_stack(self):
        print(self.stack)   
    def push_stack(self,data):
        if len(self.stack ) >= self.size: 
            print("stack over flow!")
            return
        self.stack.append(data)
        self.top += 1 
	
	def pop_stack(self):
        if self.top = -1: #當top小于等于初始值 -1 時說明stack數據列表為空
            print("stack is empty!")
            return
        ret = self.stack.pop() #stack數據列表不為空就取出最后進的值,列表數據數量就少一個
        self.top -= 1 
        return ret
        
if __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()

執行結果:

四、取棧頂 peek_stack

class Stack():
    def __init__ (self,size):
        self.size = size
        self.top = -1
        self.stack = [] 
    def display_stack(self):
        print(self.stack)   
    def push_stack(self,data):
        if len(self.stack ) >= self.size: 
            print("stack over flow!")
            return
        self.stack.append(data) 
        self.top += 1 

	def peek_stack(self):
        if self.top == -1: #當棧內沒有數據時 提示 stack is empty!
            print("stack is empty!")
            return
        peek = self.stack[self.top] #棧不為空時,將棧頂的數據提取出來
        return peek
        
if __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 數據結構之樹的概念詳解
  • python三種數據結構及13種創建方法總結
  • python數據結構的排序算法
  • Python內置數據結構列表與元組示例詳解
  • Python二進制數據結構Struct的具體使用
  • python用sqlacodegen根據已有數據庫(表)結構生成對應SQLAlchemy模型
  • Python數據結構之圖的存儲結構詳解
  • Python數據結構之二叉排序樹的定義、查找、插入、構造、刪除
  • Python數據結構之優先級隊列queue用法詳解
  • Python數據結構詳細

標簽:黑龍江 上海 益陽 惠州 黔西 鷹潭 常德 四川

巨人網絡通訊聲明:本文標題《詳解python數據結構之棧stack》,本文關鍵詞  詳解,python,數據結構,之棧,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《詳解python數據結構之棧stack》相關的同類信息!
  • 本頁收集關于詳解python數據結構之棧stack的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: xxxxtube69| 琪琪午夜理论片在线观看播放| 秋霞无码免费AV鲁丝片久久久 | ??成人福利午夜A片| 欧美午夜无码毛片Av久久小说| 男人把女人摸出白浆| 1010毛茸茸网站| 公么的大龟慢慢挺进我的体内| 欧产?日产?国产精品VR| 年轻的女教练4伦理HD高清中文| 国产亚洲精品97在线观看| 黄色片免费看| 无限资源日本2019免费观看-高清在线| 色之久久综合AV人妻熟女黑寡妇 | 亚洲第一区二区三区| 91在线无码精品秘?cos西施| 男生操女生动态图| 国产精品短视频免费观看 | 清宫性史3风流名妓在线观看| 久久久久久久久久免费| 黄色网址亚洲| 太粗受不了我不要了| 黄色片应用| 国产永久免费裸体美女视频| 美国伦理片大全手机在线| 午夜影院app| 三级aa| 免费无码婬片AAAA片软件| 国产-第一页-浮力影院| 后进式猛烈XX00动态图片| 欲情(高H,NP)| 免费一级欧美黑寡妇a观看| toilet中国厕所偷窥| 女人18片毛片90分钟| 办公室揉弄高潮嗯啊免费视频欧美 | 美女爆?吸乳羞羞免费网站妖精| 桃色综合网| 淫模| 男人舔女人下面的视频| 国产福利99| 国产黄A三级三级三级看三级男男|