一文帶你了解C++中deque的使用
1)deque的定義及基本用法
要使用deque,我們需要包含頭文件,定義deque對象如下:
#include <deque> using namespace std; deque<int> dq; // 定義deque對象dq,其中元素類型為int型
deque支持的基本操作如下:
- 在deque的隊首插入元素:push_front()方法。
- 在deque的隊尾插入元素:push_back()方法。
- 刪除deque隊首的元素:pop_front()方法。
- 刪除deque隊尾的元素:pop_back()方法。
- deque的長度:size()方法。
- 判斷deque是否為空:empty()方法。
- 訪問deque隊首元素:front()方法。
- 訪問deque隊尾元素:back()方法。
示例代碼如下:
#include <iostream>
#include <deque>
using namespace std;
int main()
{
deque<int> dq;
dq.push_front(1); // 在隊首插入元素1
dq.push_back(2); // 在隊尾插入元素2
dq.push_front(3); // 在隊首插入元素3
dq.pop_back(); // 刪除隊尾元素2
cout << "長度:" << dq.size() << endl; // 打印長度
while(!dq.empty()){
cout << dq.front() << ' '; // 打印隊列中的每一個元素
dq.pop_front(); // 刪除隊首元素
}
return 0;
}執(zhí)行結(jié)果:
長度:2
3 1
2)deque的迭代器
deque支持迭代器,可以按照指針的方式遍歷deque中的所有元素。deque迭代器支持前向訪問,但不支持隨機訪問,即不支持下標操作。deque迭代器又分為普通迭代器和反向迭代器,可以分別用begin(),end(),rbegin(),rend()方法來獲取。
示例代碼如下:
#include <iostream>
#include <deque>
using namespace std;
int main()
{
deque<int> dq;
dq.push_front(1);
dq.push_back(2);
dq.push_back(3);
dq.push_front(4);
cout << "正向遍歷:";
for(deque<int>::iterator it=dq.begin();it!=dq.end();it++)
cout << *it << ' '; // 打印所有元素
cout << endl;
cout << "反向遍歷:";
for(deque<int>::reverse_iterator it=dq.rbegin();it!=dq.rend();it++)
cout << *it << ' '; // 打印所有元素(反向)
cout << endl;
return 0;
}執(zhí)行結(jié)果:
正向遍歷:4 1 2 3
反向遍歷:3 2 1 4
3)deque的性能
對于在最差情況下,即內(nèi)存池容量已滿的情況,deque在表現(xiàn)上比較優(yōu),它的時間復雜度為O(1),因為deque在前端和后端進行插入和刪除的操作所需時間復雜度為O(1),但如果在中間進行插入和刪除,則時間復雜度為O(N),因為因為需要把后面的元素往后移動。同時,它的空間復雜度為O(N),其中N表示deque中元素的個數(shù)。
4)deque的應用:滑動窗口問題
滑動窗口問題是指在一個序列中找出所有長度為k的子序列,并且每次移動一個單位,重復執(zhí)行這個操作,最終得到所有的子序列。這個問題在處理字符串問題,尤其是搜索問題中經(jīng)常出現(xiàn)。我們可以用deque來解決這個問題,將待處理的數(shù)據(jù)元素存入到deque中,每次向右滑動窗口的時候從左邊移除最先加入的元素,同時從右邊添加一個新的元素。
示例代碼如下:
#include <iostream>
#include <deque>
using namespace std;
void printMax(int arr[], int n, int k)
{
deque<int> dq; // 存儲元素下標,用于判斷窗口是否失效,同時也維護了單調(diào)性
for (int i=0; i<k; i++) {
while (!dq.empty() && arr[i] >= arr[dq.back()])
dq.pop_back(); // 維護單調(diào)性,刪除隊列中元素使其單調(diào)遞增
dq.push_back(i); // 將元素下標存入隊列
}
for (int i=k; i<n; i++) {
cout << arr[dq.front()] << " "; // 打印當前窗口中的最大值
while (!dq.empty() && dq.front() <= i-k)
dq.pop_front(); // 刪除隊首元素,判斷隊首元素是否已失效
while (!dq.empty() && arr[i] >= arr[dq.back()])
dq.pop_back(); // 維護單調(diào)性,刪除隊列中元素使其單調(diào)遞增
dq.push_back(i); // 將元素下標存入隊列
}
cout << arr[dq.front()] << endl; // 打印最后一個窗口中的最大值
}
int main()
{
int arr[] = {4, 3, 5, 4, 2, 5, 6, 7};
int n = sizeof(arr) / sizeof(arr[0]);
int k = 3;
printMax(arr, n, k);
return 0;
}此示例代碼中,我們定義了一個deque用于存儲元素下標,同時維護單調(diào)性,使得隊列中的元素單調(diào)遞增。在每次可取的滑動窗口過程中,只需找到隊列中的最大值。這個示例中的時間復雜度為O(N)。
以上便是關(guān)于C++中deque的基本用法和應用的相關(guān)介紹,希望對你有所幫助。
到此這篇關(guān)于一文帶你了解C++中deque的使用的文章就介紹到這了,更多相關(guān)C++ deque內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C語言與C++動態(tài)通訊錄超詳細實現(xiàn)流程
這篇文章主要為大家介紹了C語言與C++動態(tài)實現(xiàn)通訊錄,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2022-05-05
基于Matlab實現(xiàn)離散系統(tǒng)分岔圖的繪制
這篇文章主要介紹了如何利用Matlab實現(xiàn)離散分岔圖的繪制,文中的示例代碼講解詳細,對我們學習Matlab有一定的幫助,需要的可以參考一下2022-04-04
MongoDB?C?驅(qū)動程序安裝(libmongoc)?和?BSON?庫(libbson)方法
這篇文章主要介紹了安裝?MongoDB?C?驅(qū)動程序?(libmongoc)?和?BSON?庫?(libbson),本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-09-09
Qt專欄之模態(tài)與非模態(tài)對話框的實現(xiàn)
這篇文章主要介紹了Qt專欄之模態(tài)與非模態(tài)對話框的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-04-04
C語言使用openSSL庫AES模塊實現(xiàn)加密功能詳解
這篇文章主要介紹了C語言使用openSSL庫AES模塊實現(xiàn)加密功能,詳細分析了C語言加密的相關(guān)概念、原理及AES模塊加密具體實現(xiàn)技巧,需要的朋友可以參考下2017-05-05

