欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

c++優(yōu)先隊(duì)列的用法有哪些-創(chuàng)新互聯(lián)

今天小編給大家分享的是c++優(yōu)先隊(duì)列的用法有哪些,相信很多人都不太了解,為了讓大家更加了解c++優(yōu)先隊(duì)列的用法,所以給大家總結(jié)了以下內(nèi)容,一起往下看吧。一定會有所收獲的哦。

十年品牌的成都網(wǎng)站建設(shè)公司,成百上千家企業(yè)網(wǎng)站設(shè)計(jì)經(jīng)驗(yàn).價格合理,可準(zhǔn)確把握網(wǎng)頁設(shè)計(jì)訴求.提供定制網(wǎng)站建設(shè)、商城網(wǎng)站制作、重慶小程序開發(fā)、響應(yīng)式網(wǎng)站等服務(wù),我們設(shè)計(jì)的作品屢獲殊榮,是您值得信賴的專業(yè)網(wǎng)站制作公司。

c++優(yōu)先隊(duì)列用法詳解

優(yōu)先隊(duì)列也是隊(duì)列這種數(shù)據(jù)結(jié)構(gòu)的一種。它的操作不僅局限于隊(duì)列的先進(jìn)先出,可以按邏輯(按大值或者最小值等出隊(duì)列)。

普通的隊(duì)列是一種先進(jìn)先出的數(shù)據(jù)結(jié)構(gòu),元素在隊(duì)列尾追加,而從隊(duì)列頭刪除。

在優(yōu)先隊(duì)列中,元素被賦予優(yōu)先級。當(dāng)訪問元素時,具有最高優(yōu)先級的元素最先刪除。優(yōu)先隊(duì)列具有最高級先出 (first in, largest out)的行為特征。

首先要包含頭文件#include<queue>, 他和queue不同的就在于我們可以自定義其中數(shù)據(jù)的優(yōu)先級, 讓優(yōu)先級高的排在隊(duì)列前面,優(yōu)先出隊(duì)。

優(yōu)先隊(duì)列具有隊(duì)列的所有特性,包括隊(duì)列的基本操作,只是在這基礎(chǔ)上添加了內(nèi)部的一個排序,它本質(zhì)是一個堆實(shí)現(xiàn)的。

和隊(duì)列基本操作相同:

top 訪問隊(duì)頭元素

empty 隊(duì)列是否為空

size 返回隊(duì)列內(nèi)元素個數(shù)

push 插入元素到隊(duì)尾 (并排序)

emplace 原地構(gòu)造一個元素并插入隊(duì)列

pop 彈出隊(duì)頭元素

swap 交換內(nèi)容

定義:priority_queue<Type, Container, Functional>

Type 就是數(shù)據(jù)類型,Container 就是容器類型(Container必須是用數(shù)組實(shí)現(xiàn)的容器,比如vector,deque等等,但不能用 list。STL里面默認(rèn)用的是vector),F(xiàn)unctional 就是比較的方式。

當(dāng)需要用自定義的數(shù)據(jù)類型時才需要傳入這三個參數(shù),使用基本數(shù)據(jù)類型時,只需要傳入數(shù)據(jù)類型,默認(rèn)是大頂堆。

一般是:

//升序隊(duì)列
priority_queue <int,vector<int>,greater<int> > q;
//降序隊(duì)列
priority_queue <int,vector<int>,less<int> >q;

//greater和less是std實(shí)現(xiàn)的兩個仿函數(shù)(就是使一個類的使用看上去像一個函數(shù)。其實(shí)現(xiàn)就是類中實(shí)現(xiàn)一個operator(),這個類就有了類似函數(shù)的行為,就是一個仿函數(shù)類了)

1、基本類型優(yōu)先隊(duì)列的例子:

#include<iostream>
#include <queue>
using namespace std;
int main() 
{
    //對于基礎(chǔ)類型 默認(rèn)是大頂堆
    priority_queue<int> a; 
    //等同于 priority_queue<int, vector<int>, less<int> > a;
    
    //      這里一定要有空格,不然成了右移運(yùn)算符↓↓
    priority_queue<int, vector<int>, greater<int> > c;  //這樣就是小頂堆
    priority_queue<string> b;

    for (int i = 0; i < 5; i++) 
    {
        a.push(i);
        c.push(i);
    }
    while (!a.empty()) 
    {
        cout << a.top() << ' ';
        a.pop();
    } 
    cout << endl;

    while (!c.empty()) 
    {
        cout << c.top() << ' ';
        c.pop();
    }
    cout << endl;

    b.push("abc");
    b.push("abcd");
    b.push("cbd");
    while (!b.empty()) 
    {
        cout << b.top() << ' ';
        b.pop();
    } 
    cout << endl;
    return 0;
}

運(yùn)行結(jié)果:

4 3 2 1 0
0 1 2 3 4
cbd abcd abc
請按任意鍵繼續(xù). . .

2、用pair做優(yōu)先隊(duì)列元素的例子:

規(guī)則:pair的比較,先比較第一個元素,第一個相等比較第二個。

#include <iostream>
#include <queue>
#include <vector>
using namespace std;
int main() 
{
    priority_queue<pair<int, int> > a;
    pair<int, int> b(1, 2);
    pair<int, int> c(1, 3);
    pair<int, int> d(2, 5);
    a.push(d);
    a.push(c);
    a.push(b);
    while (!a.empty()) 
    {
        cout << a.top().first << ' ' << a.top().second << '\n';
        a.pop();
    }
}

運(yùn)行結(jié)果:

2 5
1 3
1 2
請按任意鍵繼續(xù). . .

3、用自定義類型做優(yōu)先隊(duì)列元素的例子

#include <iostream>
#include <queue>
using namespace std;

//方法1
struct tmp1 //運(yùn)算符重載<
{
    int x;
    tmp1(int a) {x = a;}
    bool operator<(const tmp1& a) const
    {
        return x < a.x; //大頂堆
    }
};

//方法2
struct tmp2 //重寫仿函數(shù)
{
    bool operator() (tmp1 a, tmp1 b) 
    {
        return a.x < b.x; //大頂堆
    }
};

int main() 
{
    tmp1 a(1);
    tmp1 b(2);
    tmp1 c(3);
    priority_queue<tmp1> d;
    d.push(b);
    d.push(c);
    d.push(a);
    while (!d.empty()) 
    {
        cout << d.top().x << '\n';
        d.pop();
    }
    cout << endl;

    priority_queue<tmp1, vector<tmp1>, tmp2> f;
    f.push(b);
    f.push(c);
    f.push(a);
    while (!f.empty()) 
    {
        cout << f.top().x << '\n';
        f.pop();
    }
}

運(yùn)行結(jié)果:

3
2
1
 
3
2
1
請按任意鍵繼續(xù). . .

關(guān)于c++優(yōu)先隊(duì)列的用法有哪些就分享到這里了,希望以上內(nèi)容可以對大家有一定的參考價值,可以學(xué)以致用。如果喜歡本篇文章,不妨把它分享出去讓更多的人看到。

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。

當(dāng)前題目:c++優(yōu)先隊(duì)列的用法有哪些-創(chuàng)新互聯(lián)
文章出自:http://chinadenli.net/article34/ehose.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供云服務(wù)器、網(wǎng)站維護(hù)、網(wǎng)站設(shè)計(jì)公司、網(wǎng)站營銷網(wǎng)站設(shè)計(jì)、品牌網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站優(yōu)化排名
国产精品免费福利在线| 国产欧美日韩视频91| 亚洲国产综合久久天堂| 久久中文字幕中文字幕中文| 九九热精品视频免费在线播放| 欧美久久一区二区精品| 国产成人精品国内自产拍| 偷自拍亚洲欧美一区二页| 又黄又硬又爽又色的视频| 大香蕉伊人精品在线观看| 少妇淫真视频一区二区| 观看日韩精品在线视频| 亚洲天堂国产精品久久精品| 日韩一级一片内射视频4k| 免费黄片视频美女一区| 国产级别精品一区二区视频 | 国产亚洲系列91精品| 美国欧洲日本韩国二本道| 久久综合九色综合欧美| 欧美一区二区三区喷汁尤物| 亚洲清纯一区二区三区| 午夜视频成人在线观看| 久久精品国产99精品亚洲| 亚洲av又爽又色又色| 欧美一区日韩一区日韩一区| 福利专区 久久精品午夜| 国产成人av在线免播放观看av| 一个人的久久精彩视频| 在线视频免费看你懂的| 老外那个很粗大做起来很爽| 精品国模一区二区三区欧美| 中文字幕精品少妇人妻| 日韩精品一区二区三区av在线| 亚洲国产精品av在线观看| 高中女厕偷拍一区二区三区| 男女午夜视频在线观看免费| 亚洲中文字幕在线乱码av| 婷婷九月在线中文字幕| 亚洲欧美国产精品一区二区| 97人妻人人揉人人躁人人| 国产在线视频好看不卡|