日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

priority_queue优先队列

發布時間:2024/10/5 编程问答 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 priority_queue优先队列 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.


引入
優先隊列是一種特殊的隊列,在學習堆排序的時候就有所了解。

那么優先隊列是什么呢??
說白了,就是一種功能強大的隊列。

它的功能強大在哪里呢??
四個字:自動排序。

優先隊列的頭文件&&聲明
首先,你需要

#include<queue> using namespace std;


這兩個頭文件。

其次,一個優先隊列聲明的基本格式是:?
priority_queue<結構類型> 隊列名;?
比如:

priority_queue <int> i; priority_queue <double> d;


不過,我們最為常用的是這幾種:

priority_queue <node> q; //node是一個結構體 //結構體里重載了‘<’小于符號 priority_queue <int,vector<int>,greater<int> > q; //不需要#include<vector>頭文件 //注意后面兩個“>”不要寫在一起,“>>”是右移運算符 priority_queue <int,vector<int>,less<int> >q;


我們將在下文來講講這幾種聲明方式的不同。

優先隊列的基本操作
與隊列的基本操作如出一轍。?
如果想要了解請點擊這里,看關于隊列的介紹。

以一個名為q的優先隊列為例。

q.size();//返回q里元素個數 q.empty();//返回q是否為空,空則返回1,否則返回0 q.push(k);//在q的末尾插入k q.pop();//刪掉q的第一個元素 q.top();//返回q的第一個元素 q.back();//返回q的末尾元素



優先隊列的特性
上文已經說過了,自動排序。?
怎么個排法呢??
在這里介紹一下:

默認的優先隊列(非結構體結構)

priority_queue <int> q;


這樣的優先隊列是怎樣的?讓我們寫程序驗證一下。

#include<cstdio> #include<queue> using namespace std; priority_queue <int> q; int main() {q.push(10),q.push(8),q.push(12),q.push(14),q.push(6);while(!q.empty())printf("%d ",q.top()),q.pop(); }



程序大意就是在這個優先隊列里依次插入10、8、12、14、6,再輸出。?
結果是什么呢??
14 12 10 8 6?
也就是說,它是按從大到小排序的!

默認的優先隊列(結構體,重載小于)
先看看這個結構體是什么。

struct node {int x,y;bool operator < (const node & a) const{return x<a.x;} };



這個node結構體有兩個成員,x和y,它的小于規則是x小者小。?
再來看看驗證程序:

#include<cstdio> #include<queue> using namespace std; struct node {int x,y;bool operator < (const node & a) const{return x<a.x;} }k; priority_queue <node> q; int main() {k.x=10,k.y=100; q.push(k);k.x=12,k.y=60; q.push(k);k.x=14,k.y=40; q.push(k);k.x=6,k.y=80; q.push(k);k.x=8,k.y=20; q.push(k);while(!q.empty()){node m=q.top(); q.pop();printf("(%d,%d) ",m.x,m.y);} }




程序大意就是插入(10,100),(12,60),(14,40),(6,20),(8,20)這五個node。?
再來看看它的輸出:?

(14,40) (12,60) (10,100) (8,20) (6,80)

它也是按照重載后的小于規則,從大到小排序的。

less和greater優先隊列
還是以int為例,先來聲明:

priority_queue <int,vector<int>,less<int> > p; priority_queue <int,vector<int>,greater<int> > q;


話不多說,上程序和結果:

#include<cstdio> #include<queue> using namespace std; priority_queue <int,vector<int>,less<int> > p; priority_queue <int,vector<int>,greater<int> > q; int a[5]={10,12,14,6,8}; int main() {for(int i=0;i<5;i++)p.push(a[i]),q.push(a[i]);printf("less<int>:")while(!p.empty())printf("%d ",p.top()),p.pop(); ?pritntf("\ngreater<int>:")while(!q.empty())printf("%d ",q.top()),q.pop(); }


結果:?

less<int>:14 12 10 8 6?
greater<int>:6 8 10 12 14

所以,我們可以知道,less是從大到小,greater是從小到大。

作個總結
為了裝13方便,在平時,建議大家寫:

priority_queue<int,vector<int>,less<int> >q; priority_queue<int,vector<int>,greater<int> >q;


平時如果用從大到小不用后面的vector<int>,less<int>,可能到時候要改成從小到大,你反而會搞忘怎么寫greater<int>,反而得不償失。

例子

?

Fence Repair

https://blog.csdn.net/weixin_43272781/article/details/83050793

?

?

總結

以上是生活随笔為你收集整理的priority_queue优先队列的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 在线不卡日韩 | 在线小视频你懂的 | 狠狠干狠狠搞 | a∨视频 | 成人手机视频在线观看 | 亚洲天堂8 | 黄色a级在线观看 | 国产精品无码一区二区无人区多人 | 国产亚洲自拍av | 狠狠爱天天干 | 福利一区视频 | 国产视频一区二区三区四区五区 | 四虎网站在线 | 在线观看黄 | 美女脱了裤子让男人桶 | www射| 毛片网| 黄色长视频 | 亚洲女人在线 | 久久午夜夜伦鲁鲁片无码免费 | 日本一区二区三区在线观看视频 | 日韩熟女一区二区 | 人人做 | 人妻无码一区二区三区 | 黑人黄色录像 | 色七七网站 | 狠狠做深爱婷婷综合一区 | 日韩中文字幕视频在线 | 欧美久久一级 | 少妇又色又紧又黄又刺激免费 | 97自拍偷拍视频 | 国产综合视频一区 | 91成人网页| 精品国产一区一区二区三亚瑟 | 久久久性色精品国产免费观看 | 午夜噜噜 | 日韩小视频在线 | 色网在线免费观看 | 亚洲午夜免费视频 | 邻居少妇张开腿让我爽了在线观看 | 亚洲精品四区 | 在线播放亚洲精品 | 日韩在线观看视频一区 | 草草影院欧美 | 色呦呦在线免费观看 | 91手机在线 | www.五月天com | 香蕉久久网站 | 强行挺进白丝老师里呻吟 | 欧美日韩一区二区电影 | 在线电影一区二区三区 | 欧美老熟妇乱xxxxx | 久久男人的天堂 | 精品视频免费在线 | 91尤物国产福利在线观看 | 国产肉体xxxx裸体784大胆 | 黄色大片免费的 | 免费无码国产精品 | 亚洲色精品三区二区一区 | 中日韩免费视频 | 国产人妻精品一区二区三区不卡 | 久操久 | 99久久久成人国产精品 | 偷拍视频一区二区 | 粗大黑人巨茎大战欧美成人 | 欧美日韩一区二区三区在线视频 | 色一区二区三区 | 国产做爰免费视频观看 | 久久综合久色欧美综合狠狠 | 成人天堂av| xxx日本少妇 | 日韩在线观看视频免费 | 久久咪咪| 91美女视频网站 | 久久亚洲av永久无码精品 | 亚洲一区二区高清 | 蜜桃视频一区二区 | 国产伦精品一区二区三区视频痴汉 | 欧美精品手机在线 | 精品免费 | sm久久捆绑调教精品一区 | 67194国产 | 琪琪色在线视频 | 一本色道久久综合无码人妻 | 日韩第四页 | 91久久久久久久久久久久久 | 亚洲欧美视频在线播放 | 国产日韩欧美在线 | 国产a∨精品一区二区三区仙踪林 | 草草草av | 久久久久国产综合av天堂 | 久久精品三级视频 | 日本韩国免费观看 | 成人午夜视频在线 | av一本在线| 四虎影视成人永久免费观看亚洲欧美 | 久久性av | 日韩av在线播放不卡 | 国产精品视频一二三 |