亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時間:2019年12月31日 10:24:33   作者:華山青竹  
這篇文章主要介紹了c++優(yōu)先隊列(priority_queue)用法詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

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

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

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

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

和隊列基本操作相同:

  • top 訪問隊頭元素
  • empty 隊列是否為空
  • size 返回隊列內(nèi)元素個數(shù)
  • push 插入元素到隊尾 (并排序)
  • emplace 原地構(gòu)造一個元素并插入隊列
  • pop 彈出隊頭元素
  • swap 交換內(nèi)容

定義:priority_queue<Type, Container, Functional>
Type 就是數(shù)據(jù)類型,Container 就是容器類型(Container必須是用數(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)是大頂堆。
一般是:

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

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

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

#include<iostream>
#include <queue>
using namespace std;
int main() 
{
  //對于基礎(chǔ)類型 默認(rèn)是大頂堆
  priority_queue<int> a; 
  //等同于 priority_queue<int, vector<int>, less<int> > a;
  
  //   這里一定要有空格,不然成了右移運算符↓↓
  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;
}

運行結(jié)果:

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

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

規(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();
  }
}

運行結(jié)果:

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

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

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

//方法1
struct tmp1 //運算符重載<
{
  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();
  }
}

運行結(jié)果:

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

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • C++實現(xiàn)打印兩個有序鏈表公共部分的方法

    C++實現(xiàn)打印兩個有序鏈表公共部分的方法

    這篇文章主要介紹了C++實現(xiàn)打印兩個有序鏈表公共部分的方法,涉及C++針對有序鏈表的簡單遍歷、比較相關(guān)操作技巧,需要的朋友可以參考下
    2017-05-05
  • vscode實現(xiàn)本地代碼自動同步到遠(yuǎn)程機器的步驟

    vscode實現(xiàn)本地代碼自動同步到遠(yuǎn)程機器的步驟

    這篇文章主要介紹了vscode實現(xiàn)本地代碼自動同步到遠(yuǎn)程機器的步驟,本文分步驟給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-06-06
  • C++靜態(tài)庫與動態(tài)庫文件的生成和使用教程

    C++靜態(tài)庫與動態(tài)庫文件的生成和使用教程

    庫文件是計算機上的一類文件,可以簡單的把庫文件看成一種代碼倉庫,它提供給使用者一些可以直接拿來用的變量、函數(shù)和類,下面這篇文章主要給大家介紹了關(guān)于C++靜態(tài)庫與動態(tài)庫文件的生成和使用的相關(guān)資料,需要的朋友可以參考下
    2023-03-03
  • 解析在WTL下使用雙緩沖的實現(xiàn)方法

    解析在WTL下使用雙緩沖的實現(xiàn)方法

    本篇文章是對在WTL下使用雙緩沖的實現(xiàn)方法進行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05
  • C語言詳細(xì)講解位運算符的使用

    C語言詳細(xì)講解位運算符的使用

    C語?既具有?級語?的特點,?具有低級語?的特性,如?持位運算就是其具體體現(xiàn)。這是因為,C語?最初是為取代匯編語?設(shè)計系統(tǒng)軟件?設(shè)計的,因此C語?必須?持位運算等匯編操作。位運算就是對字節(jié)或字內(nèi)的?進制數(shù)位進?測試、抽取、設(shè)置或移位等操作
    2022-04-04
  • C語言實現(xiàn)帶頭雙向循環(huán)鏈表的接口

    C語言實現(xiàn)帶頭雙向循環(huán)鏈表的接口

    這篇文章主要為大家詳細(xì)介紹了C語言實現(xiàn)帶頭雙向循環(huán)鏈表的接口,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • C語言實現(xiàn)中綴表達式轉(zhuǎn)換為后綴表達式

    C語言實現(xiàn)中綴表達式轉(zhuǎn)換為后綴表達式

    這篇文章主要為大家詳細(xì)介紹了C語言實現(xiàn)中綴表達式轉(zhuǎn)換為后綴表達式,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-04-04
  • C++算法學(xué)習(xí)之回溯法的應(yīng)用

    C++算法學(xué)習(xí)之回溯法的應(yīng)用

    這篇文章介紹了C++算法中回溯法的一些應(yīng)用,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-05-05
  • c語言實現(xiàn)含遞歸清場版掃雷游戲

    c語言實現(xiàn)含遞歸清場版掃雷游戲

    掃雷大家應(yīng)該都玩過,這是一個十分經(jīng)典的游戲,下面這篇文章主要給大家介紹了關(guān)于c語言實現(xiàn)含遞歸清場版掃雷游戲的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2021-11-11
  • 詳解C/C++中new?A與new?A()的區(qū)別

    詳解C/C++中new?A與new?A()的區(qū)別

    這篇文章主要通過一些簡單的示例為大家詳細(xì)介紹一下C/C++中new?A與new?A()的區(qū)別,文中的示例代碼簡潔易懂,快跟隨小編一起學(xué)習(xí)起來吧
    2023-07-07

最新評論