C++中sort()函數(shù)和priority_queue容器中比較函數(shù)的區(qū)別詳析
前言
- 普通的queue是一種先進先出的數(shù)據(jù)結構,元素在隊列尾追加,而從隊列頭刪除。
- priority_queue中元素被賦予優(yōu)先級。在創(chuàng)建的時候根據(jù)優(yōu)先級進行了按照從大到小或者從小到大進行了自動排列(大頂堆or小頂堆)??梢砸設(log n) 的效率查找一個隊列中的最大值或者最小值;
雖然兩者第三個參數(shù)默認的都是less,但兩者參數(shù)比較函數(shù)的區(qū)別是相反的:
小細節(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;
}
運行結果

則:
- 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;
}
運行結果:

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

struct cmp1 //等價于less的內部構造,效果和上面分析的less情況一樣
{
opeartor()(data x1,data x2){
return x1<x2;
}
};
struct cmp2 //等價于less的內部構造,效果和上面分析的greater情況一樣
{
opeartor()(data x1,data x2){
return x1>x2;
}
};
總結
當比較函數(shù)是x1.data<x2.data時: 等價于less
- sort()最終會把序列處理成升序
- priority_queue會處理成大根堆–>遍歷輸出為降序結構;
當比較函數(shù)是x1.data>x2.data時:等價于greater
- sort()最終會把序列處理成降序
- priority_queue會處理成小根堆–>遍歷輸出為升序結構;
他倆是反著的
到此這篇關于C++中sort()函數(shù)和priority_queue容器中比較函數(shù)的區(qū)別的文章就介紹到這了,更多相關C++比較函數(shù)的區(qū)別內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
C++實現(xiàn)LeetCode(157.用Read4來讀取N個字符)
這篇文章主要介紹了C++實現(xiàn)LeetCode(157.用Read4來讀取N個字符),本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內容,需要的朋友可以參考下2021-07-07
windows?使用ffmpeg?.a靜態(tài)庫讀取Wav音頻并保存PCM的方法
這篇文章主要介紹了windows?使用ffmpeg?.a靜態(tài)庫讀取Wav音頻并保存PCM,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2024-02-02

