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::span
- std::forward_list
- std::deque
- std::deque<T,Allocator>::push_front
- std::deque<T,Allocator>::pop_front
- std::deque<T,Allocator>::end, std::deque<T,Allocator>::cend
- std::deque<T,Allocator>::deque
- std::deque<T,Allocator>::~deque
- std::deque<T,Allocator>::operator=
- std::deque<T,Allocator>::empty
- 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::deque
std::deque
  template <class T>
  using deque = std::deque<T, std::pmr::polymorphic_allocator<T>>;
std::deque ï¼ double-ended queue ï¼å端éåï¼æ¯æä¸æ 顺åºå®¹å¨ï¼å®å
许å¨å
¶é¦å°¾ä¸¤æ®µå¿«éæå
¥åå é¤ãå¦å¤ï¼å¨ deque ä»»ä¸ç«¯æå
¥æå é¤ä¸ä¼éæ³åæåå
¶ä½å
ç´ çæéæå¼ç¨ã
ä¸ std::vector ç¸åï¼ deque çå ç´ ä¸æ¯ç¸æ¥åå¨çï¼å ¸åå®ç°ç¨åç¬åé çåºå®å¤§å°æ°ç»çåºåï¼å¤å é¢å¤çç»è®°ï¼è¿è¡¨ç¤ºä¸æ 访é®å¿ é¡»è¿è¡äºæ¬¡æéè§£å¼ç¨ï¼ä¸ä¹ç¸æ¯ vector ç䏿 访é®åªè¿è¡ä¸æ¬¡ã
deque çå卿éèªå¨æ©å±åæ¶ç¼©ãæ©å¼ deque æ¯æ©å± std::vector 便å®ï¼å 为å®ä¸æ¶åå°å¤å¶æ¢åå ç´ å°æ°å åä½ç½®ãå¦ä¸æ¹é¢ï¼ deque å ¸åå°æ¥æè¾å¤§çæå°å åå¼éï¼åªä¿æä¸ä¸ªå ç´ ç deque å¿ é¡»åé å ¶æ´ä¸ªå 鍿°ç»ï¼ä¾å¦ 64 ä½ libstdc++ ä¸ä¸ºå¯¹è±¡å¤§å° 8 åï¼ 64 ä½ libc++ ä¸ä¸ºå¯¹è±¡å¤§å° 16 åæ 4096 åèçè¾å¤§è ï¼ã
deque ä¸å¸¸è§æä½çå¤æåº¦ï¼æçï¼å¦ä¸ï¼
- éæºè®¿é®ââå¸¸æ° O(1)
- å¨ç»å°¾æèµ·å§æå ¥æç§»é¤å ç´ ââå¸¸æ° O(1)
- æå ¥æç§»é¤å ç´ ââçº¿æ§ O(n)
std::deque æ»¡è¶³å®¹å¨ (Container) ãå
·åé
å¨å®¹å¨ (AllocatorAwareContainer) ãåºåå®¹å¨ (SequenceContainer) åå¯éå®¹å¨ (ReversibleContainer) çè¦æ±ã
模æ¿å½¢å
| T | - | å
ç´ çç±»åã
| ||||
| Allocator | - | ç¨äºè·å/éæ¾å ååæé /ææå åä¸å ç´ çåé å¨ãç±»åå¿ é¡»æ»¡è¶³åé å¨ (Allocator) çè¦æ±ãè¥ Allocator::value_type ä¸ T ä¸ååè¡ä¸ºæªå®ä¹ã |
è¿ä»£å¨éæ³å
| æ¬èæªå®æ |
æ¤èæä»å°éä¸åç¡®å¤ï¼æ´å¤ç»è请æ¥çæ¶ååç¬æå彿°ç页é¢
| æä½ | è¢«éæ³å |
|---|---|
| ææåªè¯»æä½ | å³ä¸ |
| swap ã std::swap | å°¾åè¿ä»£å¨å¯è½è¢«éæ³åï¼å®ç°å®ä¹ï¼ |
| shrink_to_fit ã clear ã insert ã emplace ã push_front ã push_back ã emplace_front ã emplace_back |
å§ç» |
| erase | è¥å¨èµ·å§æ¦é¤ââä»
被æ¦é¤å
ç´ è¥å¨æ«å°¾æ¦é¤ââä»
被æ¦é¤å
ç´ åå°¾åè¿ä»£å¨ |
| resize | è¥æ°å¤§å°å°äºæ§è
ï¼ä»
被æ¦é¤å
ç´ åå°¾åè¿ä»£å¨ è¥æ°å¤§å°å¤§äºæ§è
ï¼éæ³åææè¿ä»£å¨ |
| pop_front | ä» ææå被æ¦é¤å ç´ è |
| pop_back | ä» ææå被æ¦é¤å ç´ è åå°¾åè¿ä»£å¨ |
鿳忳¨æ
- ä» deque ä»»ä¸ç«¯æå ¥æ¶ï¼ insert å emplace ä¸ä¼éæ³åå¼ç¨ã
- push_front ã push_back ã emplace_front å emplace_back ä¸ä¼éæ³åä»»ä½å° deque å ç´ çå¼ç¨ã
- ä» deque ä»»ä¸ç«¯æ¦é¤æ¶ï¼ erase ã pop_front å pop_back ä¸ä¼éæ³åå°æªæ¦é¤å ç´ çå¼ç¨ã
- 以è¾å°ç大å°è°ç¨ resize ä¸ä¼éæ³åä»»ä½å°æªæ¦é¤å ç´ çå¼ç¨ã
- 以è¾å¤§ç大å°è°ç¨ resize ä¸ä¼éæ³åä»»ä½å° deque å ç´ çå¼ç¨ã
æåç±»å
| Â | |||||
| æåç±»å | å®ä¹ | ||||
value_type
|
T | ||||
allocator_type
|
Allocator | ||||
size_type
|
æ ç¬¦å·æ´æ°ç±»åï¼éå¸¸æ¯ std::size_t ï¼ | ||||
difference_type
|
æç¬¦å·æ´æ°ç±»åï¼éå¸¸æ¯ std::ptrdiff_t ï¼ | ||||
reference
|
| ||||
const_reference
|
| ||||
pointer
|
| ||||
const_pointer
|
| ||||
iterator
|
éçéæºè®¿é®è¿ä»£å¨ (LegacyRandomAccessIterator) | ||||
const_iterator
|
å¸¸éæºè®¿é®è¿ä»£å¨ | ||||
reverse_iterator
|
std::reverse_iterator<iterator> | ||||
const_reverse_iterator
|
std::reverse_iterator<const_iterator> | ||||
æå彿°
æé deque (å ¬å¼æå彿°) | |
ææ deque (å ¬å¼æå彿°) | |
| èµå¼ç»å®¹å¨ (å ¬å¼æå彿°) | |
| å°å¼èµç»å®¹å¨ (å ¬å¼æå彿°) | |
| è¿åç¸å
³çåé
å¨ (å ¬å¼æå彿°) | |
å ç´ è®¿é® | |
| è®¿é®æå®çå
ç´ ï¼åæ¶è¿è¡è¶çæ£æ¥ (å ¬å¼æå彿°) | |
| è®¿é®æå®çå
ç´ (å ¬å¼æå彿°) | |
| 访é®ç¬¬ä¸ä¸ªå
ç´ (å ¬å¼æå彿°) | |
| è®¿é®æåä¸ä¸ªå
ç´ (å ¬å¼æå彿°) | |
è¿ä»£å¨ | |
| è¿åæå容å¨ç¬¬ä¸ä¸ªå
ç´ çè¿ä»£å¨ (å ¬å¼æå彿°) | |
| è¿åæå容å¨å°¾ç«¯çè¿ä»£å¨ (å ¬å¼æå彿°) | |
| è¿åæå容卿åå
ç´ çéåè¿ä»£å¨ (å ¬å¼æå彿°) | |
| è¿åæåå端çéåè¿ä»£å¨ (å ¬å¼æå彿°) | |
容é | |
| æ£æ¥å®¹å¨æ¯å¦ä¸ºç©º (å ¬å¼æå彿°) | |
| è¿å容纳çå
ç´ æ° (å ¬å¼æå彿°) | |
| è¿åå¯å®¹çº³çæå¤§å
ç´ æ° (å ¬å¼æå彿°) | |
| (C++11) |
éè¿éæ¾æªä½¿ç¨çå
ååå°å
åçä½¿ç¨ (å ¬å¼æå彿°) |
ä¿®æ¹å¨ | |
| æ¸
é¤å
容 (å ¬å¼æå彿°) | |
| æå
¥å
ç´ (å ¬å¼æå彿°) | |
| (C++11) |
å使é å
ç´ (å ¬å¼æå彿°) |
| æ¦é¤å
ç´ (å ¬å¼æå彿°) | |
| å°å
ç´ æ·»å å°å®¹å¨æ«å°¾ (å ¬å¼æå彿°) | |
| (C++11) |
å¨å®¹å¨æ«å°¾å°±å°æé å
ç´ (å ¬å¼æå彿°) |
| ç§»é¤æ«å
ç´ (å ¬å¼æå彿°) | |
| æå
¥å
ç´ å°å®¹å¨èµ·å§ (å ¬å¼æå彿°) | |
| (C++11) |
å¨å®¹å¨å¤´é¨å°±å°æé å
ç´ (å ¬å¼æå彿°) |
| ç§»é¤é¦å
ç´ (å ¬å¼æå彿°) | |
| æ¹å容å¨ä¸å¯åå¨å
ç´ çä¸ªæ° (å ¬å¼æå彿°) | |
| 交æ¢å
容 (å ¬å¼æå彿°) | |
éæå彿°
| (C++20 ä¸ç§»é¤)(C++20 ä¸ç§»é¤)(C++20 ä¸ç§»é¤)(C++20 ä¸ç§»é¤)(C++20 ä¸ç§»é¤)(C++20) |
æç
§åå
¸é¡ºåºæ¯è¾ deque ä¸çå¼ (彿°æ¨¡æ¿) |
| ç¹å std::swap ç®æ³ (彿°æ¨¡æ¿) | |
| æ¦é¤æææ»¡è¶³ç¹å®å¤å«æ åçå
ç´ (彿°æ¨¡æ¿) |
æ¨å¯¼æå¼(C++17 èµ·)
示ä¾
#include <iostream> #include <deque>  int main() { // åå»ºå®¹çº³æ´æ°ç deque std::deque<int> d = {7, 5, 16, 8};  // ä» deque çé¦å°¾æ·»å æ´æ° d.push_front(13); d.push_back(25);  // è¿ä»£å¹¶æå° deque çå¼ for(int n : d) { std::cout << n << '\n'; } }
è¾åºï¼
13 7 5 16 8 25