Python 操作數據結構隊列 queue和 雙端隊列 deque

“”"
隊列(Queue)和雙端隊列(Deque, Double-ended Queue)都是線性數據結構,但它們在操作上有所不同:

隊列(Queue):

隊列遵循先進先出(FIFO, First-In-First-Out)原則。
元素只能從隊尾添加(enqueue),并從隊頭移除(dequeue)。
標準的隊列不允許直接訪問或修改隊列中間的元素。
Python標準庫中的queue模塊提供了不同類型的隊列實現,如Queue、LifoQueue(后進先出)、PriorityQueue(優先級隊列)等。

雙端隊列(Deque):

雙端隊列在兩端都可以進行添加和移除操作,即允許從隊頭添加(enqueue)和移除(dequeue),同時也允許從隊尾添加(append)和移除(pop)。
它可以當作普通隊列使用,也可以當作棧(Stack)來用,因為棧是后進先出(LIFO)的數據結構,而雙端隊列的右端添加和移除功能恰好符合這一特性。
雙端隊列還可以進行任意位置的元素插入和刪除(如果支持的話),這使得它比標準隊列更加靈活。
“”"

Queue

import queue
from collections import dequeq = queue.Queue()q.put('item1')
q.put('item2')item = q.get()
print(item)item = q.get()
print(item)if q.empty():print("Queue is empty")print('*'*50)q2 = deque()
q2.append('data1')
q2.append('data2')
q2.appendleft('space1')
q2.appendleft('space2')print(q2) # deque(['space2', 'space1', 'data1', 'data2'])
d1 = q2.pop()
d2 = q2.popleft()
d3 = q2.pop()
d4 = q2.popleft()print(d1)
print(d2)
print(d3)
print(d4)if not q2:print('deque is empty!')

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/711556.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/711556.shtml
英文地址,請注明出處:http://en.pswp.cn/news/711556.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

List集合的Stream流式操作實現數據類型轉換

目錄 問題現象: 問題分析: 解決方法: 拓展: 1、Collectors.toList() 2、Collectors.toCollection(ArrayList::new) 3、Collectors.toCollection(LinkedList::new) 4、Collectors.toCollection(LinkedHashSet::new) 5、Collector…

MAC M1 安裝mongodb7.0.5 版本

1、進入官網 Download MongoDB Community Server | MongoDBDownload MongoDB Community Server non-relational database to take your next big project to a higher level!https://www.mongodb.com/try/download/community 2、選擇版本 3、下載后解壓 放到 /usr/local 并修改…

Facebook Messenger鏈接分享:如何創建鏈接并設置自動化內容

Facebook Messenger鏈接是指基于Facebook用戶名創建的會話鏈接,用戶可以在其Facebook頁面的設置部分復制此鏈接進行分享。然后將該鏈接直接粘貼到獨立站、電子郵件、名片或社交媒體中,讓目標受眾可以一鍵進入對話。為了滿足某些商家的需求,Fa…

vue3中的ref和reactive的區別

vue3中的ref和reactive的區別 1、響應式數據2、ref3、reactive4、ref VS reactive5、往期回顧總結: 1、響應式數據 處理響應式數據時到底是該用ref還是reactive... 響應式數據是指在 Vue.js 中,當數據發生變化時,相關的視圖會自動更新以反映…

【bash】2、手把手實現一個 bash shell:多個機器批量執行 shell 命令,支持 ip 補全

文章目錄 一、需求:多臺機器批量遠程執行 shell 命令1.1 業務需求拆解為腳本需求1.2 幫助函數:使用說明文檔1.3 main 函數框架 二、功能:單機 sshp 執行2.1 fullip 函數:實現 ip 補全2.1.1 參數說明2.1.2 定義全局變量2.1.3 實現&…

Cu-HCP-H035 Cu-HCP-R250銅合金高精度零部件

Cu-HCP-H035 Cu-HCP-R250銅合金高精度零部件 CDA102-3/4H EN1982-CC333G EN1982-CC492K BS1400-LG4 EN1982-CC491K BS1400-LG2 CuNi18Zn19Pb1/CW408J CuNi12Zn38Mn5Pb2/CW407J CuNi12Zn30Pb1/CW406J CuNi12Zn29/CW405J CuNi12Zn25Pb1/CW404J CuNi10Zn42Pb2/CW402J CuNi10Zn27/C…

Pytorch 復習總結 4

Pytorch 復習總結,僅供筆者使用,參考教材: 《動手學深度學習》Stanford University: Practical Machine Learning 本文主要內容為:Pytorch 深度學習計算。 本文先介紹了深度學習中自定義層和塊的方法,然后介紹了一些…

基于Beego 1.12.3的簡單website實現

參考 用Beego開發web應用 https://www.cnblogs.com/zhangweizhong/p/10919672.htmlBeego官網 Homepage - beego: simple & powerful Go app frameworkbuild-web-application-with-golang https://github.com/astaxie/build-web-application-with-golang/blob/master/zh/pr…

源碼的角度分析Vue2數據雙向綁定原理

什么是雙向綁定 我們先從單向綁定切入,其實單向綁定非常簡單,就是把Model綁定到View,當我們用JavaScript代碼更新Model時,View就會自動更新。那么雙向綁定就可以從此聯想到,即在單向綁定的基礎上,用戶更新…

微信開發者工具-代碼管理和碼云Github遠程倉庫集成

目錄 思考:IDE如何進行代碼管理 代碼管理方式 一、自身提供服務 二、Git 擴展 1、環境準備 2、創建項目代碼 3、進行項目Git初始化 4、在碼云新建遠程倉庫 5、將項目進行遠程倉庫關聯 三、SVN擴展 四、代碼管理 思考:IDE如何進行代碼管理 初識開…

服務器部署測試環境回顧與改進建議

任務概述: 原計劃在2小時內完成的任務,由于遇到一系列挑戰,最終耗時1.5天。任務目標是在無外網環境的服務器上建立測試環境,涉及將SSD硬盤數據遷移至服務器、SSH連接、運行測試程序并監控服務器功耗。 高效實施策略:…

fs讀取目錄、文件

fs讀取文件 process.cwd() 是 Node.js 中的一個方法,它返回 Node.js 進程的當前工作目錄。這個工作目錄通常是啟動 Node.js 進程時所在的目錄。 const fs require(fs); const path require(path);// 讀取指定目錄 const configPath path.join(process.cwd(), c…

StarRocks實戰——貝殼找房數倉實踐

目錄 前言 一、StarRocks在貝殼的應用現狀 1.1 歷史的數據分析架構 1.2 OLAP選型 1.2.1 離線場景 1.2.2 實時場景 1.2.3 StarRocks 的引入 二、StarRocks 在貝殼的分析實踐 2.1 指標分析 2.2 實時業務 2.3 可視化分析 三、未來規劃 3.1 StarRocks集群的穩定性 3…

PMP考試培訓費用多少錢?

PMP考試的相關費用包括報名費用、培訓費用和證書續證費用三個部分。 一、PMP考試報名費用: 首次報考費用為3900元,如果未通過考試可以在英文報名有效期內進行補考報名,補考費用為2500元。 付費方式是在項目管理學會官方網站上提交報考資料…

企業數字化轉型的第一步:由被動多云向主動多云轉變

隨著經濟環境、市場形勢、技術發展、用戶需求等諸多因素的變化,數字化轉型為企業進一步提升效率和競爭力、提供更加豐富的個性化產品和服務、進行業務場景創新、探尋新的增長機會和運營模式提供了嶄新的途徑。越來越多的企業意識到,數字化轉型已不是企業…

第1篇 Linux Docker安裝rabbitmq

Docker安裝RabbitMq 1、搜索rabbitmq鏡像 docker search rabbitmq2、下載rabbitmq鏡像 docker pull rabbitmq3、運行rabbitmq服務 docker run -d --name rabbitmq --restart always -p 15672:15672 -p 5672:5672 rabbitmq4、訪問rabbitmq http://192.168.1.x:15672 5、rab…

亞信安慧AntDB:打破數據孤島,實現實時處理

AntDB數據庫以其獨特的創新能力在分布式數據庫領域引領潮流。其中,融合統一與實時處理是其兩大核心創新能力,為其贏得廣泛關注與贊譽。融合統一意味著AntDB能夠將多種不同類型的數據庫融合為一體,實現數據的統一管理與處理,極大地…

電視盒子什么品牌好?資深數碼粉強推口碑電視盒子推薦

我對各類數碼產品是非常熟悉的,尤其是電視盒子,用過超十五款了,涵蓋了各個主流品牌,最近看到很多朋友在討論不知道電視盒子什么品牌好,我這次要來分享的就是口碑最好的五款電視盒子推薦給各位不懂如何選電視盒子的新手…

AI、AIGC、AGI、ChatGPT它們的區別?

今天咱們聊點熱門話題,來點科普時間——AI、AIGC、AGI和ChatGPT到底是啥?這幾個詞聽起來好像挺神秘的,但其實它們就在我們生活中。讓我們一起探索這些術語的奧秘! AI(人工智能):先說說AI&#…

數倉技術選型特點

高性能:用全并行的MPP架構數據庫,業務數據被分散存儲在多個節點上,數據分析任務被推送到數據所在位置就近執行,并行地完成大規模的數據處理工作,實現對數據處理的快速響應。 易擴展:Shared-Nothing開放架構…