全網最適合入門的物件導向程式設計教程:38 Python 常用複合資料型別-使用列表實現堆疊、佇列和雙端佇列
摘要:
在 Python 中,列表(list)是一種非常靈活的資料結構,可以用來實現堆疊(stack)、佇列(queue)和雙端佇列(deque)。這些資料結構雖然在使用時遵循不同的操作規則,但都可以透過 Python 列表來高效地實現。
原文連結:
FreakStudio的部落格
往期推薦:
學嵌入式的你,還不會物件導向??!
全網最適合入門的物件導向程式設計教程:00 物件導向設計方法導論
全網最適合入門的物件導向程式設計教程:01 物件導向程式設計的基本概念
全網最適合入門的物件導向程式設計教程:02 類和物件的 Python 實現-使用 Python 建立類
全網最適合入門的物件導向程式設計教程:03 類和物件的 Python 實現-為自定義類新增屬性
全網最適合入門的物件導向程式設計教程:04 類和物件的Python實現-為自定義類新增方法
全網最適合入門的物件導向程式設計教程:05 類和物件的Python實現-PyCharm程式碼標籤
全網最適合入門的物件導向程式設計教程:06 類和物件的Python實現-自定義類的資料封裝
全網最適合入門的物件導向程式設計教程:07 類和物件的Python實現-型別註解
全網最適合入門的物件導向程式設計教程:08 類和物件的Python實現-@property裝飾器
全網最適合入門的物件導向程式設計教程:09 類和物件的Python實現-類之間的關係
全網最適合入門的物件導向程式設計教程:10 類和物件的Python實現-類的繼承和里氏替換原則
全網最適合入門的物件導向程式設計教程:11 類和物件的Python實現-子類呼叫父類方法
全網最適合入門的物件導向程式設計教程:12 類和物件的Python實現-Python使用logging模組輸出程式執行日誌
全網最適合入門的物件導向程式設計教程:13 類和物件的Python實現-視覺化閱讀程式碼神器Sourcetrail的安裝使用
全網最適合入門的物件導向程式設計教程:全網最適合入門的物件導向程式設計教程:14 類和物件的Python實現-類的靜態方法和類方法
全網最適合入門的物件導向程式設計教程:15 類和物件的 Python 實現-__slots__魔法方法
全網最適合入門的物件導向程式設計教程:16 類和物件的Python實現-多型、方法重寫與開閉原則
全網最適合入門的物件導向程式設計教程:17 類和物件的Python實現-鴨子型別與“file-like object“
全網最適合入門的物件導向程式設計教程:18 類和物件的Python實現-多重繼承與PyQtGraph串列埠資料繪製曲線圖
全網最適合入門的物件導向程式設計教程:19 類和物件的 Python 實現-使用 PyCharm 自動生成檔案註釋和函式註釋
全網最適合入門的物件導向程式設計教程:20 類和物件的Python實現-組合關係的實現與CSV檔案儲存
全網最適合入門的物件導向程式設計教程:21 類和物件的Python實現-多檔案的組織:模組module和包package
全網最適合入門的物件導向程式設計教程:22 類和物件的Python實現-異常和語法錯誤
全網最適合入門的物件導向程式設計教程:23 類和物件的Python實現-丟擲異常
全網最適合入門的物件導向程式設計教程:24 類和物件的Python實現-異常的捕獲與處理
全網最適合入門的物件導向程式設計教程:25 類和物件的Python實現-Python判斷輸入資料型別
全網最適合入門的物件導向程式設計教程:26 類和物件的Python實現-上下文管理器和with語句
全網最適合入門的物件導向程式設計教程:27 類和物件的Python實現-Python中異常層級與自定義異常類的實現
全網最適合入門的物件導向程式設計教程:28 類和物件的Python實現-Python程式設計原則、哲學和規範大彙總
全網最適合入門的物件導向程式設計教程:29 類和物件的Python實現-斷言與防禦性程式設計和help函式的使用
全網最適合入門的物件導向程式設計教程:30 Python的內建資料型別-object根類
全網最適合入門的物件導向程式設計教程:31 Python的內建資料型別-物件Object和型別Type
全網最適合入門的物件導向程式設計教程:32 Python的內建資料型別-類Class和例項Instance
全網最適合入門的物件導向程式設計教程:33 Python的內建資料型別-物件Object和型別Type的關係
全網最適合入門的物件導向程式設計教程:34 Python的內建資料型別-Python常用複合資料型別:元組和命名元組
全網最適合入門的物件導向程式設計教程:35 Python的內建資料型別-文件字串和__doc__屬性
全網最適合入門的物件導向程式設計教程:36 Python的內建資料型別-字典
全網最適合入門的物件導向程式設計教程:37 Python常用複合資料型別-列表和列表推導式
更多精彩內容可看:
給你的 Python 加加速:一文速通 Python 平行計算
一文搞懂 CM3 微控制器除錯原理
肝了半個月,嵌入式技術棧大彙總出爐
電子計算機類比賽的“武林秘籍”
一個MicroPython的開源專案集錦:awesome-micropython,包含各個方面的Micropython工具庫
Avnet ZUBoard 1CG開發板—深度學習新選擇
SenseCraft 部署模型到Grove Vision AI V2影像處理模組
文件和程式碼獲取:
可訪問如下連結進行對文件下載:
https://github.com/leezisheng/Doc
本文件主要介紹如何使用 Python 進行物件導向程式設計,需要讀者對 Python 語法和微控制器開發具有基本瞭解。相比其他講解 Python 物件導向程式設計的部落格或書籍而言,本文件更加詳細、側重於嵌入式上位機應用,以上位機和下位機的常見串列埠資料收發、資料處理、動態圖繪製等為應用例項,同時使用 Sourcetrail 程式碼軟體對程式碼進行視覺化閱讀便於讀者理解。
相關示例程式碼獲取連結如下:https://github.com/leezisheng/Python-OOP-Demo
正文
使用列表實現堆疊
列表方法使得列表可以很方便的作為一個堆疊來使用,堆疊作為特定的資料結構,最先進入的元素最後一個被釋放(先進後出)。用 append() 方法可以把一個元素新增到堆疊頂。用不指定索引的 pop() 方法可以把一個元素從堆疊頂釋放出來。
stack = [3, 4, 5]
stack.append(6)
stack.append(7)
print(stack)
print(stack.pop())
print(stack)
print(stack.pop())
print(stack.pop())
print(stack)
執行結果如下:
使用列表實現佇列
也可以把列表當做佇列用,只是在佇列裡第一加入的元素,第一個取出來;但是拿列表用作這樣的目的效率不高。在列表的最後新增或者彈出元素速度快,然而在列表裡插入或者從頭部彈出速度卻不快(因為所有其他的元素都得一個一個地移動)。示例程式碼如下:
class Queue(object):
'''
使用列表實現佇列
'''
def __init__(self):
'''
初始化操作
'''
self.__list = []
def enqueue(self, item):
'''
往佇列中新增元素
'''
self.__list.append(item)
def dequeue(self):
'''
從佇列頭部取出元素
'''
return self.__list.pop(0)
def is_empty(self):
'''
判斷列表是否為空
'''
return self.__list == []
def size(self):
'''
返回列表的大小
'''
return len(self.__list)
s = Queue()
s.enqueue(1)
s.enqueue(2)
s.enqueue(3)
s.enqueue(4)
print(s.__dict__)
print(s.dequeue())
print(s.dequeue())
print(s.dequeue())
print(s.dequeue())
執行結果如下:
使用列表實現雙端佇列
雙端佇列(deque,全名 double-ended-queue),是一種具有佇列和棧的性質的資料結構。雙端佇列中的元素可以從兩端彈出,其限定插入和刪除操作在表的兩端進行。雙端佇列可以在佇列的任意一端入隊和出隊。
使用列表實現雙端佇列的示例程式碼如下:
class Deque(object):
'''
雙端佇列
'''
def __init__(self):
'''
初始化列表
'''
self.__list = []
def add_front(self, item):
'''
往佇列頭部新增元素
'''
self.__list.insert(0, item)
def add_rear(self, item):
'''
往佇列尾部新增元素
'''
self.__list.append(item)
def pop_front(self):
'''
從佇列頭部刪除元素
'''
return self.__list.pop(0)
def pop_rear(self):
'''
從佇列頭部刪除元素
'''
return self.__list.pop()
def is_empty(self):
'''
判斷列表是否為空
'''
return self.__list == []
def size(self):
'''
返回列表的大小
'''
return len(self.__list)