C++中sort()函數(shù)和priority_queue容器中比較函數(shù)的區(qū)別詳析
前言
- 普通的queue是一種先進先出的數(shù)據(jù)結(jié)構(gòu),元素在隊列尾追加,而從隊列頭刪除。
- priority_queue中元素被賦予優(yōu)先級。在創(chuàng)建的時候根據(jù)優(yōu)先級進行了按照從大到小或者從小到大進行了自動排列(大頂堆or小頂堆)??梢砸設(shè)(log n) 的效率查找一個隊列中的最大值或者最小值;
雖然兩者第三個參數(shù)默認(rèn)的都是less,但兩者參數(shù)比較函數(shù)的區(qū)別是相反的:
小細(xì)節(jié) sort中需要傳對象,得less(),priority_queue中需要傳類型less即可;
less情況
#include<iostream>
#include<vector>
#include<queue>
using namespace std;
int main()
{
vector<int>arr2 = {3,2,1};
sort(arr2.begin(),arr2.end(),less<int>());
//輸出sort()之后的vector
for (int i = 0; i < 3; i++) {
cout << arr2[i] << ' ';
}
cout << endl;
priority_queue<int,vector<int>,less<int>>arr;
arr.push(3);
arr.push(2);
arr.push(1);
//輸出priority_queue
while (!arr.empty()) {
cout<<arr.top()<<' ';
arr.pop();
}
cout << endl;
return 0;
}
運行結(jié)果

則:
- sort()排序是從小到大,即less是升序;
- priority_queue是大頂堆,輸出之后是從大到小,即降序;
greater情況
#include<iostream>
#include<vector>
#include<queue>
using namespace std;
int main()
{
vector<int>arr2 = {3,2,1};
sort(arr2.begin(),arr2.end(),greater<int>());
//輸出sort()之后的vector
for (int i = 0; i < 3; i++) {
cout << arr2[i] << ' ';
}
cout << endl;
priority_queue<int,vector<int>, greater<int>>arr;
arr.push(3);
arr.push(2);
arr.push(1);
//輸出priority_queue
while (!arr.empty()) {
cout<<arr.top()<<' ';
arr.pop();
}
cout << endl;
return 0;
}
運行結(jié)果:

則:
sort()排序是從大到小,即greater是降序;
priority_queue是小頂堆,輸出之后是從小到大,即升序;
自定義比較函數(shù)情況

struct cmp1 //等價于less的內(nèi)部構(gòu)造,效果和上面分析的less情況一樣
{
opeartor()(data x1,data x2){
return x1<x2;
}
};
struct cmp2 //等價于less的內(nèi)部構(gòu)造,效果和上面分析的greater情況一樣
{
opeartor()(data x1,data x2){
return x1>x2;
}
};
總結(jié)
當(dāng)比較函數(shù)是x1.data<x2.data時: 等價于less
- sort()最終會把序列處理成升序
- priority_queue會處理成大根堆–>遍歷輸出為降序結(jié)構(gòu);
當(dāng)比較函數(shù)是x1.data>x2.data時:等價于greater
- sort()最終會把序列處理成降序
- priority_queue會處理成小根堆–>遍歷輸出為升序結(jié)構(gòu);
他倆是反著的
到此這篇關(guān)于C++中sort()函數(shù)和priority_queue容器中比較函數(shù)的區(qū)別的文章就介紹到這了,更多相關(guān)C++比較函數(shù)的區(qū)別內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C語言學(xué)生信息管理系統(tǒng)設(shè)計與實現(xiàn)
這篇文章主要為大家詳細(xì)介紹了C語言學(xué)生信息管理系統(tǒng)設(shè)計與實現(xiàn),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-01-01
wince程序防止創(chuàng)建多個實例實現(xiàn)互斥作用
什么時候用的互斥?當(dāng)你的程序只允許同時打開一個的時候,就可以通過互斥來實現(xiàn),下面說的互斥,主要是針對防止程序創(chuàng)建多個實例這種情況來實現(xiàn)的2014-02-02
使用udp發(fā)送>=128K的消息會報ENOBUFS的錯誤的解決方法
在項目中選擇了unix域的數(shù)據(jù)報套接口。在使用過程中碰到了如下,問題:發(fā)送<128K的消息時,客戶、進程可以正常收發(fā)消息;發(fā)送>=128K的消息時,發(fā)送端(sendto)返回ENOBUFS的錯誤。下面小編來詳細(xì)說下2019-05-05
C語言數(shù)據(jù)結(jié)構(gòu)之隊列的定義與實現(xiàn)
隊列是一種特殊的線性表,特殊之處在于它只允許在表的前端(head)進行刪除操作,而在表的后端(tail)進行插入操作。本文將詳細(xì)講講C語言中隊列的定義與實現(xiàn),感興趣的可以了解一下2022-07-07

