【C++】stack和queue的模擬實現 雙端隊列deque的介紹

在這里插入圖片描述

🔥個人主頁: Forcible Bug Maker
🔥專欄: STL || C++

目錄

  • 🌈前言
  • 🔥stack的模擬實現
  • 🔥queue的模擬實現
  • 🔥deque(雙端隊列)
    • deque的缺陷
  • 🌈為什么選擇deque作為stack和queue的底層默認容器
  • 🌈結語

🌈前言

本篇博客的主要內容:STL庫中stack和queue的模擬實現以及deque的介紹

這部分是名副其實的獎勵內容了,stackqueue作為容器適配器,是基于一些容器實現(如:vector,list以及deque)。內部結構實現起來很容易,但是需要多多關注模板的一些使用。deque作為容器,也被我們叫做雙端隊列,常用作棧和隊列的底層適配容器。

🔥stack的模擬實現

#pragma once
#include<iostream>
#include<vector>
namespace ForcibleBugMaker
{// 模板也可以給缺省類型template<class T,class Container = std::vector<T>>class stack{public:void push(const T& x){_con.push_back(x);}void pop(){_con.pop_back();}const T& top(){return _con.back();}size_t size(){return _con.size();}bool empty(){return _con.empty();}private:Container _con;};
}

這樣使用模板,讓我們可以通過傳入不同的類型和容器從而生成不同的stack
如下:

stack<int> st1;
stack<double, vector<double>> st2;
stack<int, list<int>> st3;

在本段代碼中,st1st2的結構相同,但存儲的數據類型不相同;st1st3存儲的數據相同,但是底層的結構卻天差地別了(一個是順序結構,一個是鏈式結構)。
在這里插入圖片描述

🔥queue的模擬實現

#pragma once
#include<deque>
namespace ForcibleBugMaker
{template<class T,class Container = std::deque<T>>class queue{public:void push(const T& x){_con.push_back(x);}void pop(){_con.pop_front();}size_t size(){return _con.size();}bool empty(){return _con.empty();}const T& front(){return _con.front();}const T& back(){return _con.back();}private:Container _con;};}

queue在這里也是同樣的道理,不過由于vector不支持頭刪(pop_front),所以在提供Container類型時不要使用vector容器。

🔥deque(雙端隊列)

deque(雙端隊列):是一種雙開口的"連續"空間的數據結構,雙開口的含義是:可以在頭尾兩端進行插入和刪除操作,且時間復雜度為O(1),與vector比較,頭插效率高,不需要搬移元素;與list比較,空間利用率比較高。
在這里插入圖片描述
上圖的雙端隊列是我們假象出來的邏輯結構,實際上在底層的存儲中,是分段連續的,物理結構如圖:
在這里插入圖片描述
為維護其“整體連續”以及隨機訪問的假象,deque的迭代器設計就比較復雜,如圖:
在這里插入圖片描述
一個迭代器類型就包含四個成員變量。

成員變量作用
cur指向當前數據位置
first指向一個buffer的開始元素
last指向一個buffer的結束元素的下一位
node反向指向中控數組

deque借助迭代器維護其假象連續結構圖:
在這里插入圖片描述

deque的缺陷

與vector比較,deque的優勢是:頭部插入和刪除時,不需要搬移元素,效率特別高,而且在擴容時,也不需要搬移大量的元素,因此其效率是比vector高的。
與list比較,其底層是連續空間,空間利用率比較高,不需要存儲額外字段。

但是,deque有兩個致命缺陷:不適合遍歷,因為在遍歷時,deque的迭代器要頻繁的去檢測其是否移動到某段小空間的邊界,導致效率低下,而序列式場景中,可能需要經常遍歷,同時,在對deque容器中間元素進行插入和刪除操作時,消耗較大,因此在實際中,需要線性結構時,大多數情況下優先考慮vector和list,deque的應用并不多,而目前能看到的一個應用就是,STL用其作為stack和queue的底層數據結構

🌈為什么選擇deque作為stack和queue的底層默認容器

stack是一種后進先出的特殊線性數據結構,因此只要具有push_back()pop_back()操作的線性結構,都可以作為stack的底層容器,比如vectorlist都可以;queue是先進先出的特殊線性數據結構,只要具有push_backpop_front操作的線性結構,都可以作為queue的底層容器,比如list。但是STL中對stack和queue默認選擇deque作為其底層容器,主要是因為:

  1. stack和queue不需要遍歷(因此stack和queue沒有迭代器),只需要在固定的一端或者兩端進行操作。
  2. 在stack中元素增長時,deque比vector的效率高(擴容時不需要搬移大量數據);queue中的元素增長時,deque不僅效率高,而且內存使用率高

結合了deque的優點,而完美的避開了其缺陷。

🌈結語

本篇博客的內容到這里就要結束了,我們探索了stack和queue的底層實現,同時介紹了雙端隊列,在使用deque作為stack和list的底層默認容器時,結合了deque的優點而完美避開了其缺陷。在下一篇博客,我們將會繼續開始C++的語法學習,講解模板,繼承和多態等內容,敬請期待?

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

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

相關文章

基于Go 1.19的站點模板爬蟲

創建一個基于Go 1.19的站點模板爬蟲涉及到幾個關鍵步驟&#xff1a;初始化項目&#xff0c;安裝必要的包&#xff0c;編寫爬蟲邏輯&#xff0c;以及處理和存儲抓取的數據。下面是一個簡單的示例&#xff0c;使用goquery庫來解析HTML&#xff0c;并使用net/http來發起HTTP請求。…

【containerd】解決敲擊crictl images命令報錯問題

【Containerd】解決輸入crictl images命令報錯問題 文章目錄 【Containerd】解決輸入crictl images命令報錯問題問題復現解決辦法驗證結果參考鏈接 問題復現 [rootmaster01 ~]# crictl images WARN[0000] image connect using default endpoints: [unix:///var/run/dockershim…

七、Docker常規軟件安裝

目錄 一、總體步驟 二、安裝tomcat 1、docker hub上查找tomcat鏡像 三、安裝MySQL 1、查看MySQL鏡像 2、拉取MySQL鏡像到本地,本次拉取MySQL5.7 3、使用MySQL鏡像創建容器 4、使用Windows數據庫工具&#xff0c;連接MySQL實例 5、常見問題 6、創建MySQL容器實例 7、新…

DDP:微軟提出動態detection head選擇,適配計算資源有限場景 | CVPR 2022

DPP能夠對目標檢測proposal進行非統一處理&#xff0c;根據proposal選擇不同復雜度的算子&#xff0c;加速整體推理過程。從實驗結果來看&#xff0c;效果非常不錯 來源&#xff1a;曉飛的算法工程筆記 公眾號 論文: Should All Proposals be Treated Equally in Object Detect…

同聲傳譯app哪個好免費?對話交流推薦這5個

暑期到&#xff0c;也是旅游出行的好日子~自打周邊不少國家都開放免簽政策之后&#xff0c;出國游也變得更加方便了~對于外語水平不高的朋友來講&#xff0c;想要保證出行體驗&#xff0c;其實手上只要備好一個同聲傳譯app就OK&#xff01; 倘若你還不清楚都有哪些同聲傳譯app…

背部筋膜炎的癥狀及治療

背部筋膜炎&#xff0c;也稱為胸背肌筋膜炎&#xff0c;主要是由于勞損或風寒濕邪侵入引起的。其典型癥狀主要包括&#xff1a; 1、疼痛&#xff1a;背部筋膜一旦出現炎癥性病變&#xff0c;會對周圍交感神經組織產生刺激作用&#xff0c;從而引起不同程度的疼痛癥狀。 2、僵…

NAT:地址轉換技術

為什么會引入NAT&#xff1f; NAT&#xff08;網絡地址轉換&#xff09;的引入主要是為了解決兩個問題 IPv4地址短缺&#xff1a;互聯網快速發展&#xff0c;可用的公網IP地址越來越少。網絡安全&#xff1a;需要一種方法來保護內部網絡不被直接暴露在互聯網上。 IPv4 &…

低通濾波以及卡爾曼濾波

先講解幾個低通濾波&#xff0c;低通濾波比卡爾曼濾波簡單&#xff0c;因為卡爾曼濾波涉及到兩個輸入量&#xff0c;一個是控制量&#xff0c;一個是觀測量&#xff0c;而低通濾波是一個輸入量 1&#xff0c;利用工具箱配置低通濾波 參考地址&#xff1a;https://blog.csdn.net…

SystemUIService啟動-Android13

SystemUIService啟動-Android13 1、SystemUIService啟動2、其他SystemUI services啟動2.1 Dagger依賴注入2.2 Recents為例 1、SystemUIService啟動 SystemUI啟動&#xff0c;及其SystemUIService啟動 <!-- SystemUi service component --><string name"config_s…

應用層協議原理——可供應用程序使用的運輸服務

前面講過套接字是應用程序進程和運輸層協議之間的接口。在發送端的應用程序將報文推進該套接字。在該套接字的另一側&#xff0c;運輸層協議負責使該報文進入接收進程的套接字。 包括因特網在內的很多網絡提供了不止一種運輸層協議。當開發一個應用時&#xff0c;必須選擇一種可…

什么是海外倉管理自動化?策略及落地實施步驟指南

作為海外倉的管理者&#xff0c;你每天都面臨提高海外倉運營效率、降低成本和滿足客戶需求的問題。海外倉自動化管理技術為這些問題提供了不錯的解決思路&#xff0c;不過和任何新技術一樣&#xff0c;從策略到落地實施&#xff0c;都有一個對基礎邏輯的認識過程。 今天我們整…

重生奇跡mu的地圖名

地圖之一&#xff1a;勇者大陸 勇者大陸地處奇跡大陸中央。終年陰雨連綿&#xff0c;氣候潮濕悶熱。植物由充滿黑暗陰森氣氛的草地所構成。這里的NPC數量是所有地圖中最多的。因為地步交通要沖&#xff0c;所以也是玩家聚集最多的地方。 這里是劍士、魔法師、魔劍士和圣導師初…

vue3關于在線考試 實現監考功能 推流拉流

vue3 關于在線考試 實現監考功能&#xff0c; pc端考試 本質是直播推流的功能 使用騰訊云直播: 在線文檔 index.html <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><link rel"icon" href"/f…

永磁同步電機控制算法--最大轉矩電流比控制(虛擬信號注入法)

目前&#xff0c;國內外相關學者對 MTPA 控制方法進行了一系列的理論研究與仿真分析。通過研究取得的成果綜合來看&#xff0c;該控制方法主要有&#xff1a;直接公式計算法、曲線擬合法、查表法、搜索法、高頻信號注入法以及參數辨識法等。 之前的文章中已經介紹了直接公式計…

Java.Maths類的常用方法

Maths類的常用方法 Math 類是 Java 標準庫中的一個類&#xff0c;位于 java.lang 包中。它提供了一些基本的數學操作方法&#xff0c;這些方法都是靜態的。以下是 Math 類的所有方法&#xff1a; 數學常量 double E: 自然對數的底數&#xff08;約等于 2.718&#xff09;doub…

對于“百模大戰”,幾乎所有大佬的口風都180 °大轉變了?

文 | 智能相對論 作者 | 陳泊丞 在2024世界人工智能大會暨人工智能全球治理高級別會議產業發展主論壇上&#xff0c;百度創始人、董事長兼首席執行官李彥宏談了些對于AI大模型的看法&#xff0c;語驚四座。 他先是指出&#xff0c;“百模大戰造成了社會資源的巨大浪費&#x…

ubuntu 如何復制文件夾的內容

在Ubuntu中&#xff0c;您可以使用cp命令來復制文件夾的內容。如果您想要復制文件夾及其所有內容&#xff08;包括子文件夾&#xff09;&#xff0c;可以使用-r&#xff08;遞歸&#xff09;選項。 cp -r /path/to/source/folder/* /path/to/destination/folder/ 這個命令會將s…

現在2024年網絡安全真實情況還好就業嗎?_2024年網絡安全專業到底行不行了

2024年網絡安全行業的前景看起來非常樂觀。根據當前的趨勢和發展&#xff0c;一些趨勢和發展可能對2024年網絡安全行業產生影響&#xff1a; 5G技術的廣泛應用&#xff1a;5G技術的普及將會使互聯網的速度更快&#xff0c;同時也將帶來更多的網絡威脅和安全挑戰。網絡安全專家…

java-spring boot光速入門教程(超詳細!!)

目錄 一、引言 1.1 初始化配置 1.2 整合第三方框架 1.3 后期維護 1.4 部署工程 1.5 敏捷式開發 二、SpringBoot介紹 spring boot 2.1 搭建一個spring boot工程 2.2 使用idea創建項目 2.3 在線創建姿勢 2.4 項目的目錄結構 2.5 項目的運行方式 2.6 yml文件格式 2…

CP AUTOSAR標準之XCP(AUTOSAR_CP_SWS_XCP)(更新中……)

1 簡介和功能概述 該規范規定了AUTOSAR基礎軟件模塊XCP的功能、API和配置。XCP是主設備(工具)和從設備(設備)之間的協議描述(ASAM標準),提供以下基本功能: 同步數據采集(測量)同步數據刺激(用于快速原型設計)在線內存校準(讀/寫訪問)校準數據頁面初始化和切換用于ECU開發目的…