日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

python堆栈与队列_python语言的堆栈与队列类的实现

發布時間:2025/3/15 python 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python堆栈与队列_python语言的堆栈与队列类的实现 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

基于python語言的數據結構之堆棧與隊列的實現

# 堆棧的實現

# -*- coding: utf-8 -*-

"""

棧(stack), 是一種容器,可以存入數據元素,訪問元素,刪除元素

只允許在容器的一段存取數據

特點: 后進先出 Last in first out

"""

"""

借助list來實現堆棧

添加的方法; 壓棧(入棧)

彈棧(出棧)

Stack() 創建一個新的空棧

push(item) 添加一個新元素 item 到棧頂

pop() 彈出棧頂元素

peek() 返回棧頂元素

is_empty() 判斷棧是否為空

size() 返回棧元素的個數

"""

class Stack(object):

"""棧"""

def __init__(self):

self.__list = []

def push(self, item):

"""添加一個新元素item到棧頂"""

self.__list.append(item) # 尾部添加 ,時間復雜度o1

# self.__list.insert(0,item) 這樣從尾部添加的時間復雜度為O(n)

def pop(self):

"""彈出棧頂元素"""

return self.__list.pop()

def peek(self):

"""返回棧頂元素"""

if self.__list:

return self.__list[-1]

return None

def is_empty(self):

"""判斷棧是否為空"""

return self.__list == []

def size(self):

"""返回棧元素的個數"""

return len(self.__list)

if __name__ == '__main__':

s = Stack()

print(s.is_empty())

s.push(1)

s.push(3)

s.push(4)

print(s.pop())

print(s.pop())

print(s.pop())

# 隊列的實現

# -*- coding: utf-8 -*-

class Queue:

"""隊列"""

def __init__(self):

self.__list = []

def enqueue(self, item):

"""往隊列中添加一個元素"""

self.__list.append(item) # 時間復雜度o(1)

def dequeue(self):

"""從隊列頭部刪除一個元素"""

return self.__list.pop(0) # 時間復雜度 o(n)

def is_empty(self):

"""判斷是否為空"""

return self.__list == []

def size(self):

"""返回隊列大小"""

return len(self.__list)

if __name__ == '__main__':

s = Queue()

print(s.is_empty())

s.enqueue(1)

s.enqueue(3)

s.enqueue(4)

print(s.dequeue())

print(s.dequeue())

print(s.dequeue())

# 雙端隊列的實現

# -*- coding: utf-8 -*-

class Deque(object):

def __init__(self):

self.__list = []

def add_front(self, item):

"""往隊列頭部添加一個元素"""

self.__list.insert(0, item) # 時間復雜度o(1)

def add_rear(self, item):

"""往隊列尾部添加一個元素"""

self.__list.append(item) # 時間復雜度o(1)

def pop_rear(self):

"""從隊列尾部刪除一個元素"""

return self.__list.pop() # 時間復雜度 o(1)

def pop_front(self):

"""從隊列頭部刪除一個元素"""

return self.__list.pop(0) # 時間復雜度 o(n)

def is_empty(self):

"""判斷是否為空"""

return self.__list == []

def size(self):

"""返回隊列大小"""

return len(self.__list)

總結

以上是生活随笔為你收集整理的python堆栈与队列_python语言的堆栈与队列类的实现的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 中国在线观看视频高清免费 | 亚洲国产视频一区 | 欧美黄大片| 四虎少妇做爰免费视频网站四 | 91麻豆精品视频 | 亚洲春色一区二区三区 | 高潮无码精品色欲av午夜福利 | 欧美又粗又深又猛又爽啪啪九色 | 99自拍网 | 国产综合精品 | 国产一级片免费观看 | 丁香一区二区三区 | 三级黄色免费网站 | 色综合久久88色综合天天免费 | 激情欧美一区二区三区精品 | 国产精品夜夜躁视频 | 亚洲综合丁香 | 国产精品高潮呻吟视频 | 久久久久久免费毛片精品 | 成人性生交大片免费看r链接 | 国产色91 | 又色又爽又高潮免费视频国产 | 成人网站免费观看 | 日本色综合| 日韩字幕 | 欧美做爰全过程免费观看 | 欧美日韩国产一区二区在线观看 | 素人一区二区 | 欧美日韩综合网 | 波多野结衣一区二区三区四区 | 亚洲色图13p| 亚洲国产综合久久 | 啪啪网视频 | 欧类av怡春院 | 国产欧美一区二区三区在线 | 国产精品日韩欧美大师 | 亚洲成年人免费观看 | 超级黄色片 | 岳乳丰满一区二区三区 | 欧美成人手机视频 | 亚洲精品乱码久久久久久久 | 一区二区高潮 | 91精品视频在线播放 | 精品国产黄色片 | 亚洲欧洲另类 | 蜜桃成人无码区免费视频网站 | 日韩黄色免费 | 日本妈妈9 | www.com毛片 | 一本大道久久精品 | 亚洲产国偷v产偷v自拍涩爱 | 久久精品女人 | 国产精品免费视频一区二区 | 懂色av蜜臀av粉嫩av分 | 九色自拍视频 | 超碰狠狠干 | 淫片一级国产 | 强行挺进白丝老师里呻吟 | 日韩欧美成人一区二区 | 亚洲一区二区观看 | 91久久精品日日躁夜夜躁欧美 | 91九色视频 | 无码人妻丰满熟妇啪啪 | 免费不卡视频 | 秋霞欧美一区二区三区视频免费 | 亚洲男女视频在线观看 | 麻豆视频国产 | 国产视频一区二区 | 黄色小视频免费在线观看 | 国产成人免费在线观看 | 欧美三区在线 | 成人精品一区二区三区 | 国产污污视频在线观看 | 秋霞网一区二区三区 | 日韩电影一区二区三区四区 | 精品午夜久久 | 国产香蕉在线 | 婷婷伊人网 | 国产91丝袜在线播放九色 | 91插视频 | 五月婷网站 | 91偷拍一区二区三区精品 | 久久久久久黄色片 | av免费入口| 欧美激情在线免费 | 伊人一区二区三区四区 | 深夜成人福利 | 伊人青青草原 | 午夜av网站| 亚洲av色香蕉一区二区三区 | 潘金莲激情呻吟欲求不满视频 | 国产激情一区二区三区在线观看 | 欧美裸体视频 | 欧美a级黄色 | 丝袜国产视频 | 精品成人无码久久久久久 | 婷婷影音 | 日本中文字幕在线观看 | 天堂网在线播放 |