
- Python 基礎
- Python - 首頁
- Python - 概述
- Python - 歷史
- Python - 特性
- Python vs C++
- Python - Hello World 程式
- Python - 應用領域
- Python - 直譯器
- Python - 環境搭建
- Python - 虛擬環境
- Python - 基本語法
- Python - 變數
- Python - 資料型別
- Python - 型別轉換
- Python - Unicode 系統
- Python - 字面量
- Python - 運算子
- Python - 算術運算子
- Python - 比較運算子
- Python - 賦值運算子
- Python - 邏輯運算子
- Python - 位運算子
- Python - 成員運算子
- Python - 身份運算子
- Python - 運算子優先順序
- Python - 註釋
- Python - 使用者輸入
- Python - 數字
- Python - 布林值
- Python 控制語句
- Python - 控制流
- Python - 決策
- Python - if 語句
- Python - if else
- Python - 巢狀 if
- Python - Match-Case 語句
- Python - 迴圈
- Python - for 迴圈
- Python - for-else 迴圈
- Python - while 迴圈
- Python - break 語句
- Python - continue 語句
- Python - pass 語句
- Python - 巢狀迴圈
- Python 函式與模組
- Python - 函式
- Python - 預設引數
- Python - 關鍵字引數
- Python - 僅關鍵字引數
- Python - 位置引數
- Python - 僅位置引數
- Python - 可變引數
- Python - 變數作用域
- Python - 函式註解
- Python - 模組
- Python - 內建函式
- Python 字串
- Python - 字串
- Python - 字串切片
- Python - 修改字串
- Python - 字串連線
- Python - 字串格式化
- Python - 跳脫字元
- Python - 字串方法
- Python - 字串練習
- Python 列表
- Python - 列表
- Python - 訪問列表元素
- Python - 修改列表元素
- Python - 新增列表元素
- Python - 刪除列表元素
- Python - 遍歷列表
- Python - 列表推導式
- Python - 排序列表
- Python - 複製列表
- Python - 合併列表
- Python - 列表方法
- Python - 列表練習
- Python 元組
- Python - 元組
- Python - 訪問元組元素
- Python - 更新元組
- Python - 解包元組
- Python - 遍歷元組
- Python - 合併元組
- Python - 元組方法
- Python - 元組練習
- Python 集合
- Python - 集合
- Python - 訪問集合元素
- Python - 新增集合元素
- Python - 刪除集合元素
- Python - 遍歷集合
- Python - 合併集合
- Python - 複製集合
- Python - 集合運算子
- Python - 集合方法
- Python - 集合練習
- Python 字典
- Python - 字典
- Python - 訪問字典元素
- Python - 修改字典元素
- Python - 新增字典元素
- Python - 刪除字典元素
- Python - 字典檢視物件
- Python - 遍歷字典
- Python - 複製字典
- Python - 巢狀字典
- Python - 字典方法
- Python - 字典練習
- Python 陣列
- Python - 陣列
- Python - 訪問陣列元素
- Python - 新增陣列元素
- Python - 刪除陣列元素
- Python - 遍歷陣列
- Python - 複製陣列
- Python - 反轉陣列
- Python - 排序陣列
- Python - 合併陣列
- Python - 陣列方法
- Python - 陣列練習
- Python 檔案處理
- Python - 檔案處理
- Python - 寫入檔案
- Python - 讀取檔案
- Python - 重新命名和刪除檔案
- Python - 目錄
- Python - 檔案方法
- Python - OS 檔案/目錄方法
- Python - OS 路徑方法
- 面向物件程式設計
- Python - OOPs 概念
- Python - 類與物件
- Python - 類屬性
- Python - 類方法
- Python - 靜態方法
- Python - 建構函式
- Python - 訪問修飾符
- Python - 繼承
- Python - 多型
- Python - 方法重寫
- Python - 方法過載
- Python - 動態繫結
- Python - 動態型別
- Python - 抽象
- Python - 封裝
- Python - 介面
- Python - 包
- Python - 內部類
- Python - 匿名類和物件
- Python - 單例類
- Python - 包裝類
- Python - 列舉
- Python - 反射
- Python 錯誤與異常
- Python - 語法錯誤
- Python - 異常
- Python - try-except 塊
- Python - try-finally 塊
- Python - 丟擲異常
- Python - 異常鏈
- Python - 巢狀 try 塊
- Python - 使用者自定義異常
- Python - 日誌記錄
- Python - 斷言
- Python - 內建異常
- Python 多執行緒
- Python - 多執行緒
- Python - 執行緒生命週期
- Python - 建立執行緒
- Python - 啟動執行緒
- Python - 連線執行緒
- Python - 執行緒命名
- Python - 執行緒排程
- Python - 執行緒池
- Python - 主執行緒
- Python - 執行緒優先順序
- Python - 守護執行緒
- Python - 執行緒同步
- Python 同步
- Python - 執行緒間通訊
- Python - 執行緒死鎖
- Python - 中斷執行緒
- Python 網路程式設計
- Python - 網路程式設計
- Python - 套接字程式設計
- Python - URL 處理
- Python - 泛型
- Python 庫
- NumPy 教程
- Pandas 教程
- SciPy 教程
- Matplotlib 教程
- Django 教程
- OpenCV 教程
- Python 雜項
- Python - 日期與時間
- Python - 數學
- Python - 迭代器
- Python - 生成器
- Python - 閉包
- Python - 裝飾器
- Python - 遞迴
- Python - 正則表示式
- Python - PIP
- Python - 資料庫訪問
- Python - 弱引用
- Python - 序列化
- Python - 模板
- Python - 輸出格式化
- Python - 效能測量
- Python - 資料壓縮
- Python - CGI 程式設計
- Python - XML 處理
- Python - GUI 程式設計
- Python - 命令列引數
- Python - 文件字串
- Python - JSON
- Python - 傳送郵件
- Python - 擴充套件
- Python - 工具/實用程式
- Python - GUIs
- Python 高階概念
- Python - 抽象基類
- Python - 自定義異常
- Python - 高階函式
- Python - 物件內部
- Python - 記憶體管理
- Python - 元類
- Python - 使用元類進行超程式設計
- Python - 模擬和存根
- Python - Monkey Patching
- Python - 訊號處理
- Python - 型別提示
- Python - 自動化教程
- Python - Humanize 包
- Python - 上下文管理器
- Python - 協程
- Python - 描述符
- Python - 診斷和修復記憶體洩漏
- Python - 不可變資料結構
- Python 有用資源
- Python - 問答
- Python - 線上測驗
- Python - 快速指南
- Python - 參考
- Python - 速查表
- Python - 專案
- Python - 有用資源
- Python - 討論
- Python 編譯器
- NumPy 編譯器
- Matplotlib 編譯器
- SciPy 編譯器
Python collections.deque
在 Python 中,**deque()** 是一種資料型別,它返回一個新的 deque 物件,該物件使用來自可迭代物件的 資料從左到右初始化(使用 append())。如果未指定可迭代物件,則新的 deque 為空。
**deque** 使用 **collections** 模組實現。當我們需要執行更快的操作,例如追加和彈出元素時,我們更傾向於使用 **deque**,因為它的時間複雜度為 O(1),而 **list** 的時間複雜度為 O(n)。
語法
以下是 Python **deque()** 類的語法:
class collections.deque([iterable[, maxlen]])
引數
此資料型別接受可迭代物件作為引數。
返回值
此資料型別返回 **
示例
以下是 Python **deque()** 類的基本示例:
from collections import deque d = deque('xyz') print(d)
以下是上述程式碼的輸出:
deque(['x', 'y', 'z'])
deque 中的方法
以下是 deque() 類中存在的方法:
方法 | 功能 |
---|---|
append(x) | 將 x 新增到 deque 的右側 |
appendleft(x) | 將 x 新增到 deque 的左側 |
clear() | 刪除 deque 中的所有元素,使其長度為 0 |
copy() | 建立 deque 的淺複製。 |
count(x) | 計算 deque 中等於 x 的元素個數 |
extend(iterable) | 透過追加來自 iterable 引數的元素來擴充套件 deque 的右側 |
extendleft(iterable) | 透過追加來自 iterable 的元素來擴充套件 deque 的左側。 |
index(x[, start[, stop]]) | 返回 x 在 deque 中的位置(在索引 start 或之後,在索引 stop 之前)。返回第一個匹配項,如果未找到則引發 ValueError。 |
insert(i, x) | 在位置 i 將 x 插入到 deque 中 |
pop() | 刪除並返回 deque 右側的一個元素 |
popleft() | 刪除並返回 deque 左側的一個元素。如果沒有元素,則引發 IndexError。 |
rotate(n=1) | 將 deque 向右旋轉 n 步。如果 n 為負數,則向左旋轉 |
maxlen | deque 的最大大小,如果無界則為 None |
remove(value) | 刪除 value 的第一次出現。如果未找到,則引發 ValueError。 |
reverse() | 就地反轉 deque 的元素,然後返回 None。 |
Python deque.append() 方法
我們可以使用 **append()** 將元素新增到 deque 中。元素新增到 deque 的右端。**appendleft()** 用於將元素新增到 deque 的左端。一次只能將單個元素新增到 deque 中。
示例
在這裡,我們建立了 deque 並使用 **append()** 在 deque 的右側添加了一個元素。使用 **appendleft()**,我們在 deque() 的左側添加了一個元素:
import collections # initializing deque deque1 = collections.deque([1, 2, 3]) print("deque: ", deque1) # using append() to insert element at right end # inserts 100 at the end of deque deque1.append(100) # printing modified deque print("The deque after appending at right : ",deque1) # using appendleft() to insert element at left end # inserts 21 at the beginning of deque deque1.appendleft(21) # printing modified deque print("The deque after appending at left : ",deque1)
以下是上述程式碼的輸出:
deque: deque([1, 2, 3]) The deque after appending at right : deque([1, 2, 3, 100]) The deque after appending at left : deque([21, 1, 2, 3, 100])
Python deque.pop() 方法
deque 中的 **pop()** 方法用於從 deque 的末尾刪除元素。**popleft()** 用於刪除 deque 左端的元素。
示例
這裡,我們使用pop()方法刪除了右側末尾的元素。使用popleft()方法,我們刪除了雙端佇列左側末尾的元素。此方法一次只刪除一個元素。
import collections # initializing deque deque_1 = collections.deque([60, 11, 42, 93, 74]) print("deque: ", deque_1) # using pop() to delete element from right end of deque deque_1.pop() # printing modified deque print("The deque after deleting from right : ",deque_1) # using popleft() to delete element from left deque_1.popleft() # printing modified deque print("The deque after deleting from left : ",deque_1)
以下是上述程式碼的輸出:
deque: deque([60, 11, 42, 93, 74]) The deque after deleting from right : deque([60, 11, 42, 93]) The deque after deleting from left : deque([11, 42, 93])
Python deque.extend() 方法
deque 的extend()方法用於在雙端佇列的右側末尾新增多個元素。extendleft()方法用於在雙端佇列的左側末尾新增元素。
示例
以下是此類的另一個示例:
import collections # initializing deque deque_1 = collections.deque([1, 2, 3]) # using extend() to add numbers to right end deque_1.extend([40,50]) # printing modified deque print ("The deque after extending deque at right end :",deque_1) # using extendleft() to add numbers to left end deque_1.extendleft([70,80]) # printing modified deque print ("The deque after extending deque at left end: ",deque_1)
以下是上述程式碼的輸出:
The deque after extending deque at right end : deque([1, 2, 3, 40, 50]) The deque after extending deque at left end: deque([80, 70, 1, 2, 3, 40, 50])
Python deque.rotate() 方法
rotate()方法根據引數中指定的數字旋轉雙端佇列。如果指定的數字為負數,則向左旋轉;否則向右旋轉。
示例
這裡,我們建立了一個雙端佇列並在其上執行了旋轉操作。當我們傳遞一個負數時,從左側旋轉;當傳遞一個正數時,從右側旋轉:
from collections import deque #defined deque deque_1=deque([1,2,3,4]) #left rotation of deque deque_1.rotate(-1) print("Left Rotation Of deque :",deque_1) #right rotating of deque deque_1.rotate(2) print("Right Rotation Of deque :",deque_1)
以下是上述程式碼的輸出:
Left Rotation Of deque : deque([2, 3, 4, 1]) Right Rotation Of deque : deque([4, 1, 2, 3])