C++ åèæå
- C++11
- C++14
- C++17
- C++20
- C++ ç¼è¯å¨æ¯ææ åµè¡¨
- ç¬ç«ä¸å®¿ä¸»å®ç°
- C++ è¯è¨
- C++ å ³é®è¯
- é¢å¤çå¨
- C++ æ ååºå¤´æä»¶
- å ·åè¦æ±
- åè½ç¹æ§æµè¯ (C++20)
- å·¥å ·åº
- ç±»åæ¯æï¼åºæ¬ç±»åãRTTIãç±»åç¹æ§ï¼
- æ¦å¿µåº (C++20)
- é误å¤ç
- 卿å å管ç
- æ¥æåæ¶é´å·¥å ·
- å符串åº
- 容å¨åº
- std::array
- std::vector
- std::map
- std::unordered_map
- std::priority_queue
- std::priority_queue<T,Container,Compare>::top
- std::priority_queue<T,Container,Compare>::empty
- std::priority_queue<T,Container,Compare>::size
- std::priority_queue<T,Container,Compare>::push
- std::priority_queue<T,Container,Compare>::priority_queue
- std::priority_queue<T,Container,Compare>::~priority_queue
- std::priority_queue<T,Container,Compare>::operator=
- std::priority_queue<T,Container,Compare>::emplace
- std::priority_queue<T,Container,Compare>::pop
- std::priority_queue<T,Container,Compare>::swap
- std::priority_queue çæ¨å¯¼æå¼
- std::swap(std::priority_queue)
- std::uses_allocator<std::priority_queue>
- std::priority_queue<T,Container,Compare>::~priority_queue
- std::span
- std::forward_list
- std::deque
- std::list
- std::set
- std::multiset
- std::multimap
- std::unordered_set
- std::unordered_multiset
- std::unordered_multimap
- std::stack
- std::queue
- std::vector<bool>
- ç»ç¹ææ (C++17)
- 注é
- è¿ä»£å¨åº
- èå´åº (C++20)
- ç®æ³åº
- æ°å¼åº
- è¾å ¥/è¾åºåº
- æä»¶ç³»ç»åº
- æ¬å°ååº
- æ£å表达å¼åº
- ååæä½åº
- çº¿ç¨æ¯æåº
- å®éªæ§ C++ ç¹æ§
- æç¨çèµæº
- ç´¢å¼
- std 符å·ç´¢å¼
- åç¨æ¯æ (C++20)
- C++ å ³é®è¯
ä½ç½®ï¼é¦é¡µ > C++ åèæå >容å¨åº > std::priority_queue
std::priority_queue
| å®ä¹äºå¤´æä»¶ <queue>
|
||
| template< Â Â class T, |
||
priority_queue æ¯å®¹å¨éé å¨ï¼å®æä¾å¸¸æ°æ¶é´çï¼é»è®¤ï¼æå¤§å ç´ æ¥æ¾ï¼å¯¹æ°ä»£ä»·çæå ¥ä¸éåºã
å¯ç¨ç¨æ·æä¾ç Compare æ´æ¹é¡ºåºï¼ä¾å¦ï¼ç¨ std::greater<T> å°å¯¼è´æå°å
ç´ ä½ä¸º top() åºç°ã
ç¨ priority_queue å·¥ä½ç±»ä¼¼ç®¡çæäºéæºè®¿é®å®¹å¨ä¸çå ï¼ä¼å¿æ¯ä¸å¯è½çªç¶æå éæ³åã
模æ¿å½¢å
| T | - | åå¨çå
ç´ ç±»åãè¥ T ä¸ Container::value_type 䏿¯åä¸ç±»ååè¡ä¸ºæªå®ä¹ã (C++17 èµ·)
|
| Container | - | ç¨äºåå¨å
ç´ çåºå±å®¹å¨ç±»åã容å¨å¿
须满足åºåå®¹å¨ (SequenceContainer) çè¦æ±ï¼èå
¶è¿ä»£å¨å¿
须满足éçéæºè®¿é®è¿ä»£å¨ (LegacyRandomAccessIterator) çè¦æ±ãå¦å¤ï¼å®å¿
é¡»æä¾æ¥æé常è¯ä¹çä¸å彿°ï¼
æ åå®¹å¨ std::vector å std::deque 满足è¿äºè¦æ±ã |
| Compare | - | æä¾ä¸¥æ ¼å¼±åºçæ¯è¾ (Compare) ç±»åã |
æ³¨æ æ¯è¾ (Compare) å½¢åçå®ä¹ï¼ä½¿å¾è¥å ¶ç¬¬ä¸åæ°å¨å¼±åºä¸å äºå ¶ç¬¬äºåæ°åè¿å true ãä½å 为 priority_queue é¦å è¾åºæå¤§å ç´ ï¼æ âå æ¥âçå ç´ å®é 䏿åè¾åºãå³éå头嫿æç § æ¯è¾ (Compare) ææ½å å¼±åºçâæåâå ç´ ã
æåç±»å
| Â | |
| æåç±»å | å®ä¹ |
container_type
|
Container |
value_compare (C++17)
|
Compare
|
value_type
|
Container::value_type |
size_type
|
Container::size_type |
reference
|
Container::reference |
const_reference
|
Container::const_reference |
æå彿°
æé priority_queue (å ¬å¼æå彿°) | |
ææ priority_queue (å ¬å¼æå彿°) | |
| èµå¼ç»å®¹å¨éé
å¨ (å ¬å¼æå彿°) | |
å ç´ è®¿é® | |
| è®¿é®æ é¡¶å
ç´ (å ¬å¼æå彿°) | |
容é | |
| æ£æ¥åºå±ç容卿¯å¦ä¸ºç©º (å ¬å¼æå彿°) | |
| è¿å容纳çå
ç´ æ° (å ¬å¼æå彿°) | |
ä¿®æ¹å¨ | |
| æå
¥å
ç´ ï¼å¹¶å¯¹åºå±å®¹å¨æåº (å ¬å¼æå彿°) | |
| (C++11) |
å使é å
ç´ å¹¶æåºåºå±å®¹å¨ (å ¬å¼æå彿°) |
| å 餿 é¡¶å
ç´ (å ¬å¼æå彿°) | |
| 交æ¢å
容 (å ¬å¼æå彿°) | |
æå对象 | |
| Container c |
åºå±å®¹å¨ (åä¿æ¤æå对象) |
| Compare comp |
æ¯è¾å½æ°å¯¹è±¡ (åä¿æ¤æå对象) |
éæå彿°
| ç¹å std::swap ç®æ³ (彿°æ¨¡æ¿) |
è¾ å©ç±»
| ç¹å std::uses_allocator ç±»åç¹æ§ (彿°æ¨¡æ¿) |
æ¨å¯¼æå¼(C++17 èµ·)
示ä¾
#include <functional> #include <queue> #include <vector> #include <iostream>  template<typename T> void print_queue(T& q) { while(!q.empty()) { std::cout << q.top() << " "; q.pop(); } std::cout << '\n'; }  int main() { std::priority_queue<int> q;  for(int n : {1,8,5,6,3,4,0,9,7,2}) q.push(n);  print_queue(q);  std::priority_queue<int, std::vector<int>, std::greater<int> > q2;  for(int n : {1,8,5,6,3,4,0,9,7,2}) q2.push(n);  print_queue(q2);  // ç¨ lambda æ¯è¾å ç´ ã auto cmp = [](int left, int right) { return (left ^ 1) < (right ^ 1); }; std::priority_queue<int, std::vector<int>, decltype(cmp)> q3(cmp);  for(int n : {1,8,5,6,3,4,0,9,7,2}) q3.push(n);  print_queue(q3);  }
è¾åºï¼
9 8 7 6 5 4 3 2 1 0 0 1 2 3 4 5 6 7 8 9 8 9 6 7 4 5 2 3 0 1