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

C++中隊列queue的用法實例詳解

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

一、定義

queue是一種容器轉(zhuǎn)換器模板,調(diào)用#include< queue>即可使用隊列類。

一、queue初始化

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

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

初始化示例

1:

queue<int>q1;
queue<double>q2;  
queue<char>q3;
//默認(rèn)為用deque容器實現(xiàn)的queue;

2:

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

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

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

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

二、queue常用函數(shù)

1.常用函數(shù)

  1. push() 在隊尾插入一個元素
  2. pop() 刪除隊列第一個元素
  3. size() 返回隊列中元素個數(shù)
  4. empty() 如果隊列空則返回true
  5. front() 返回隊列中的第一個元素
  6. back() 返回隊列中最后一個元素

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

1:push()在隊尾插入一個元素

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

輸出 first

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

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

輸出 second 因為 first 已經(jīng)被pop()函數(shù)刪掉了

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

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

輸出2,因為隊列中有兩個元素

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

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

分別輸出1和0

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

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

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

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

第一行輸出first;

第二行輸出second,因為pop()已經(jīng)將first刪除了

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

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

輸出最后一個元素second

補充:queue 的基本操作舉例如下

queue入隊,如例:q.push(x); 將x 接到隊列的末端。

queue出隊,如例:q.pop(); 彈出隊列的第一個元素,注意,并不會返回被彈出元素的值。

訪問queue隊首元素,如例:q.front(),即最早被壓入隊列的元素。

訪問queue隊尾元素,如例:q.back(),即最后被壓入隊列的元素。

判斷queue隊列空,如例:q.empty(),當(dāng)隊列空時,返回true。

訪問隊列中的元素個數(shù),如例:q.size()

#include <cstdlib>
#include <iostream>
#include <queue>
using namespace std;
int main()
{
    int e,n,m;
    queue<int> q1;
    for(int i=0;i<10;i++)
       q1.push(i);
    if(!q1.empty())
    cout<<"dui lie  bu kong\n";
    n=q1.size();
    cout<<n<<endl;
    m=q1.back();
    cout<<m<<endl;
    for(int j=0;j<n;j++)
    {
       e=q1.front();
       cout<<e<<" ";
       q1.pop();
    }
    cout<<endl;
    if(q1.empty())
    cout<<"dui lie  bu kong\n";
    system("PAUSE");
    return 0;
}

運行結(jié)果:

dui lie  bu kong
10
9
0 1 2 3 4 5 6 7 8 9
dui lie  bu kong
請按任意鍵繼續(xù). . .

總結(jié)

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

相關(guān)文章

  • 詳解如何使用openssl創(chuàng)建自簽名證書

    詳解如何使用openssl創(chuàng)建自簽名證書

    這篇文章主要為大家介紹了詳解如何使用openssl創(chuàng)建自簽名證書示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-04-04
  • C語言標(biāo)準(zhǔn)時間與秒單位相互轉(zhuǎn)換

    C語言標(biāo)準(zhǔn)時間與秒單位相互轉(zhuǎn)換

    這篇文章主要介紹了C語言標(biāo)準(zhǔn)時間與秒單位相互轉(zhuǎn)換,秒單位與標(biāo)準(zhǔn)時間的轉(zhuǎn)換方式,這份代碼一般用在嵌入式單片機(jī)里比較多,比如:設(shè)置RTC時鐘的時間,從RTC里讀取秒單位時間后,需要轉(zhuǎn)換成標(biāo)準(zhǔn)時間顯示。下文分享需要的小伙伴可以參考一下
    2022-05-05
  • C語言中scanf與scnaf_s函數(shù)詳解

    C語言中scanf與scnaf_s函數(shù)詳解

    大家好,本篇文章主要講的是C語言中scanf與scnaf_s函數(shù)詳解,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下
    2022-01-01
  • 如何把C++的源代碼改寫成C代碼的方法

    如何把C++的源代碼改寫成C代碼的方法

    這篇文章主要介紹了如何把C++的源代碼改寫成C代碼,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-07-07
  • Visual?Studio2022的完全卸載及安裝到D盤的操作方法

    Visual?Studio2022的完全卸載及安裝到D盤的操作方法

    這篇文章主要介紹了Visual?Studio2022的完全卸載以及完全安裝到D盤,因為VS如果隨便寫在會有很多很多的亂七八糟的東西掉出來,所以我們選擇制式一點的卸載方式,需要的朋友可以參考下
    2022-09-09
  • C語言基礎(chǔ)之二分查找知識最全匯總

    C語言基礎(chǔ)之二分查找知識最全匯總

    這篇文章主要介紹了C語言基礎(chǔ)之二分查找知識最全匯總,文中有非常詳細(xì)的二分查找基礎(chǔ)知識詳解,對正在學(xué)習(xí)C語言基礎(chǔ)的小伙伴們有非常好的幫助,需要的朋友可以參考下
    2021-04-04
  • C語言實現(xiàn)“幸運數(shù)”的實例詳解

    C語言實現(xiàn)“幸運數(shù)”的實例詳解

    這篇文章主要介紹了C語言實現(xiàn)“幸運數(shù)”的實例詳解的相關(guān)資料,需要的朋友可以參考下
    2017-07-07
  • vc6.0中c語言控制臺程序中的定時技術(shù)(定時器)

    vc6.0中c語言控制臺程序中的定時技術(shù)(定時器)

    這篇文章主要介紹了vc6.0中c語言控制臺程序中的定時技術(shù)(定時器),需要的朋友可以參考下
    2014-04-04
  • Cocos2d-x中獲取系統(tǒng)時間和隨機(jī)數(shù)實例

    Cocos2d-x中獲取系統(tǒng)時間和隨機(jī)數(shù)實例

    這篇文章主要介紹了Cocos2d-x中獲取系統(tǒng)時間和隨機(jī)數(shù)實例,本文代碼含有大量注釋來講解獲取系統(tǒng)時間和隨機(jī)數(shù)的方法,需要的朋友可以參考下
    2014-09-09
  • C++實現(xiàn)歸并排序(MergeSort)

    C++實現(xiàn)歸并排序(MergeSort)

    這篇文章主要為大家詳細(xì)介紹了C++實現(xiàn)歸并排序,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-04-04

最新評論