欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++超細(xì)致講解隊(duì)列queue的使用

 更新時(shí)間:2022年05月09日 09:33:36   作者:panamera12  
隊(duì)列先進(jìn)先出,即只能在容器的末尾添加新元素,只能從頭部移除元素,下面這篇文章主要給大家介紹了關(guān)于C++中隊(duì)列queue用法的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下

queue介紹

只能訪問 queue<T> 容器適配器的第一個(gè)和最后一個(gè)元素。只能在容器的末尾添加新元素,只能從頭部移除元素。

許多程序都使用了 queue 容器。queue 容器可以用來表示超市的結(jié)賬隊(duì)列或服務(wù)器上等待執(zhí)行的數(shù)據(jù)庫事務(wù)隊(duì)列。對于任何需要用 FIFO 準(zhǔn)則處理的序列來說,使用 queue 容器適配器都是好的選擇。

調(diào)用#include< queue>即可使用隊(duì)列類

queue<Type,Container> (<數(shù)據(jù)類型,容器類型>)

初始化時(shí)必須要有數(shù)據(jù)類型,容器可省略,省略時(shí)則默認(rèn)為deque類型

queue<int>q1;

queue<double>q2;

queue<char>q3;

//默認(rèn)為用deque容器實(shí)現(xiàn)的queue;

queue<char, list<char>>q1;//用list容器實(shí)現(xiàn)的queue

queue<int, deque<int>>q2;//用deque容器實(shí)現(xiàn)的queue

queue 的生成方式和 stack 相同,下面展示如何創(chuàng)建一個(gè)保存字符串對象的

std::queue<std::string> words;

也可以使用拷貝構(gòu)造函數(shù):

std::queue<std::string> copy_words {words}; // A duplicate of words

stack<T>、queue<T> 這類適配器類都默認(rèn)封裝了一個(gè) deque<T> 容器,也可以通過指定第二個(gè)模板類型參數(shù)來使用其他類型的容器:

std::queue<std::string, std::list<std::string>>words;

底層容器必須提供這些操作:front()、back()、push_back()、pop_front()、empty() 和 size()。

注意:不能用vector容器初始化queue

因?yàn)閝ueue轉(zhuǎn)換器要求容器支持front()、back()、push_back()及 pop_front(),說明queue的數(shù)據(jù)從容器后端入棧而從前端出棧。所以可以使用deque和list對queue初始化,而vector因其缺少pop_front(),不能用于queue。

queue常用函數(shù)

1.常用函數(shù)

  • push() 在隊(duì)尾插入一個(gè)元素
  • pop() 刪除隊(duì)列第一個(gè)元素
  • size() 返回隊(duì)列中元素個(gè)數(shù)
  • empty() 如果隊(duì)列空則返回true
  • front() 返回隊(duì)列中的第一個(gè)元素
  • back() 返回隊(duì)列中最后一個(gè)元素

2.函數(shù)運(yùn)用示例

1:push()在隊(duì)尾插入一個(gè)元素

 queue <string> q;
    q.push("first");
    q.push("second");
    cout<<q.front()<<endl;

輸出 first

2:pop() 將隊(duì)列中最靠前位置的元素刪除,沒有返回值

queue <string> q;
	q.push("first");
	q.push("second");
	q.pop();
	cout<<q.front()<<endl;

輸出 second

因?yàn)?first 已經(jīng)被pop()函數(shù)刪掉了

3:size() 返回隊(duì)列中元素個(gè)數(shù)

queue <string> q;

q.push("first");

q.push("second");

cout<<q.size()<<endl;

//輸出2,因?yàn)殛?duì)列中有兩個(gè)元素

4:empty() 如果隊(duì)列空則返回true

queue <string> q;
    cout<<q.empty()<<endl;
    q.push("first");
    q.push("second");
    cout<<q.empty()<<endl;

分別輸出1和0

最開始隊(duì)列為空,返回值為1(ture);

插入兩個(gè)元素后,隊(duì)列不為空,返回值為0(false);

5:front() 返回隊(duì)列中的第一個(gè)元素

queue <string> q;

q.push("first");

q.push("second");

cout<<q.front()<<endl;

q.pop();

cout<<q.front()<<endl;

第一行輸出first;

第二行輸出second,因?yàn)閜op()已經(jīng)將first刪除了

6:back() 返回隊(duì)列中最后一個(gè)元素

queue <string> q;

q.push("first");

q.push("second");

cout<<q.back()<<endl;

輸出最后一個(gè)元素second

到此這篇關(guān)于C++超細(xì)致講解隊(duì)列queue的使用的文章就介紹到這了,更多相關(guān)C++隊(duì)列queue內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C++解決業(yè)務(wù)辦理時(shí)間問題示例解析

    C++解決業(yè)務(wù)辦理時(shí)間問題示例解析

    這篇文章主要為大家介紹了C++解決業(yè)務(wù)辦理時(shí)間問題示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12
  • C語言中建立和刪除文件連接的相關(guān)函數(shù)講解

    C語言中建立和刪除文件連接的相關(guān)函數(shù)講解

    這篇文章主要介紹了C語言中建立和刪除文件連接的相關(guān)函數(shù)講解,分別為link和unlink函數(shù)的使用,需要的朋友可以參考下
    2015-09-09
  • c語言 深入理解函數(shù)的遞歸

    c語言 深入理解函數(shù)的遞歸

    這一章講解的是函數(shù)的遞歸,因?yàn)檫f歸函數(shù)是一個(gè)非常重要求解復(fù)雜問題的方法之一,在學(xué)習(xí)算法的過程之中我們也會遇到他,所以我想對它進(jìn)行一次講解,希望能幫助其他人,也能幫助我自己來梳理一遍。下面我會通過一些題目的講解去認(rèn)識遞歸函數(shù)
    2022-02-02
  • 深入解析C語言中typedef的四個(gè)用途

    深入解析C語言中typedef的四個(gè)用途

    以下是對C語言中typedef的四個(gè)用途進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過來參考下
    2013-08-08
  • vscode 配置 C/C++ 編譯環(huán)境的詳細(xì)圖文教程

    vscode 配置 C/C++ 編譯環(huán)境的詳細(xì)圖文教程

    這篇文章主要介紹了vscode 配置 C/C++ 編譯環(huán)境的詳細(xì)教程,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-05-05
  • C++11的functional模塊介紹和使用案例

    C++11的functional模塊介紹和使用案例

    functional模塊是C++ 11提供了一組函數(shù)對象和算法,用于增強(qiáng)C++的函數(shù)式編程能力,本文主要介紹了C++11的functional模塊介紹和使用案例,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-02-02
  • 詳解c++中signal信號攜帶數(shù)據(jù)的接收與發(fā)送

    詳解c++中signal信號攜帶數(shù)據(jù)的接收與發(fā)送

    這篇文章主要為大家詳細(xì)介紹了c++中signal信號攜帶數(shù)據(jù)的接收與發(fā)送的相關(guān)知識,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2024-01-01
  • C語言實(shí)現(xiàn)繪制繞線畫的示例代碼

    C語言實(shí)現(xiàn)繪制繞線畫的示例代碼

    繞線畫簡單點(diǎn)來說,就是在木板上釘一圈釘子,通過繞線進(jìn)行構(gòu)圖,最終呈現(xiàn)出一幅圖像。本文將用C語言實(shí)現(xiàn)這一效果,感興趣的小伙伴可以嘗試一下
    2022-11-11
  • CreateCompatibleDC()函數(shù)案例詳解

    CreateCompatibleDC()函數(shù)案例詳解

    這篇文章主要介紹了CreateCompatibleDC()函數(shù)案例詳解,本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • 下標(biāo)操作符重載模擬多維數(shù)組詳解

    下標(biāo)操作符重載模擬多維數(shù)組詳解

    雖然不能直接實(shí)現(xiàn)一對下標(biāo)操作符重載,但是我們可以間接模擬。思路是這樣的,先通過單下標(biāo)操作返回一個(gè)具有下標(biāo)操作能力的左值,對左值進(jìn)行下標(biāo)操作,兩個(gè)下標(biāo)操作表達(dá)式聯(lián)立就實(shí)現(xiàn)了雙下標(biāo)操作
    2013-09-09

最新評論