सी ++ लाइब्रेरी - <deque>

परिचय

Deque के लिए संक्षिप्त है Double Ended Queue। यह एक अनुक्रम कंटेनर है जो इसे बदल सकता है आकार रनटाइम। कंटेनर एक ऐसी वस्तु है जो एक ही प्रकार का डेटा रखती है। अनुक्रम कंटेनर रैखिक अनुक्रम में तत्वों को कड़ाई से संग्रहीत करते हैं।

स्मृति के विभिन्न विखंडू में छल के तत्व बिखरे हो सकते हैं। कंटेनर निरंतर समय में किसी भी तत्व तक सीधे पहुंच की अनुमति देने के लिए आवश्यक जानकारी संग्रहीत करता है। वैक्टरों के विपरीत, बासी को सन्निहित स्मृति स्थानों पर संग्रहीत करने की गारंटी नहीं है। इसलिए यह पॉइंटर्स को ऑफसेट करके डेटा तक सीधी पहुंच की अनुमति नहीं देता है। लेकिन यह सबस्क्रिप्ट ऑपरेटर [] का उपयोग करके किसी भी तत्व तक सीधी पहुंच सक्षम करता है।

रन समय में दोनों सिरों से आवश्यकतानुसार सिकुड़ या सिकुड़ सकते हैं। भंडारण की आवश्यकता आंतरिक आवंटनकर्ता द्वारा स्वचालित रूप से पूरी की जाती है । Deque वैक्टर के समान कार्यक्षमता प्रदान करता है, लेकिन किसी भी छोर से डेटा डालने और हटाने का कुशल तरीका प्रदान करता है।

शून्य आकार के देवता भी मान्य हैं। उस स्थिति में deque.begin () और deque.end () एक ही स्थान पर इंगित करता है। लेकिन सामने () या पीछे () कॉल करने का व्यवहार अपरिभाषित है।

परिभाषा

नीचे <deque> हैडर फ़ाइल से std :: deque की परिभाषा दी गई है

template < class T, class Alloc = allocator<T> > class deque;

मापदंडों

  • T - निहित तत्व का प्रकार।

    टी को उपयोगकर्ता-परिभाषित प्रकार सहित किसी अन्य डेटा प्रकार द्वारा प्रतिस्थापित किया जा सकता है।

  • Alloc - एलोकेटर ऑब्जेक्ट का प्रकार।

    डिफ़ॉल्ट रूप से, आबंटक वर्ग टेम्पलेट का उपयोग किया जाता है, जो सरलतम मेमोरी आवंटन मॉडल को परिभाषित करता है और मूल्य-स्वतंत्र है।

सदस्य प्रकार

निम्नलिखित सदस्य प्रकारों को पैरामीटर के रूप में उपयोग किया जा सकता है या सदस्य कार्यों द्वारा वापसी प्रकार का उपयोग किया जा सकता है।

अनु क्रमांक। सदस्य प्रकार परिभाषा
1 मान प्रकार टी (टेम्पलेट का पहला पैरामीटर)
2 allocator_type एलोक (टेम्पलेट का दूसरा पैरामीटर)
3 संदर्भ मान प्रकार&
4 const_reference const value_type और
5 सूचक मान प्रकार*
6 const_pointer const value_type *
7 इटरेटर value_type के लिए एक यादृच्छिक अभिगमकर्ता
8 const_iterator const value_type के लिए एक यादृच्छिक अभिगमकर्ता
9 reverse_iterator std :: Rev_iterator <iterator>
10 const_reverse_iterator std :: Rev_iterator <const_iterator>
1 1 आकार प्रकार size_t
12 difference_type ptrdiff_t

<Deque> से कार्य

नीचे <deque> हैडर से सभी तरीकों की सूची दी गई है।

कंस्ट्रक्टर्स

अनु क्रमांक। विधि और विवरण
1 deque :: deque डिफ़ॉल्ट कंस्ट्रक्टर

शून्य तत्व के साथ एक खाली deque बनाता है।

2 deque :: deque fill constructor

n तत्वों के साथ एक नया deque बनाएं और deque के प्रत्येक तत्व को वैल असाइन करें

3 deque :: deque रेंज कंस्ट्रक्टर

पहले से लेकर आखिरी तक की सीमा में कई तत्वों के साथ एक छल का निर्माण करता है ।

4 deque :: deque कॉपी कंस्ट्रक्टर

मौजूदा कंटेनर में मौजूद प्रत्येक तत्वों की प्रतिलिपि के साथ एक छल का निर्माण करता है।

5 deque :: deque चाल निर्माणकर्ता

चाल शब्दार्थ का उपयोग कर अन्य की सामग्री के साथ एक छल का निर्माण करता है।

6 deque :: deque initializer सूची निर्माणकर्ता

प्रारंभिक सूची से एक छल का निर्माण करता है।

नाशक

अनु क्रमांक। विधि और विवरण
1 Deque :: ~ Deque

यह स्मृति से निपटाकर ऑब्जेक्ट को नष्ट कर देता है।

सदस्य कार्य

अनु क्रमांक। विधि और विवरण
1 deque :: रेंज संस्करण असाइन करें

पुराने तत्वों को बदलकर नए तत्वों को नए मान प्रदान करें।

2 deque :: असाइन संस्करण भरें

पुराने तत्वों को बदलकर नए तत्वों को नए मान प्रदान करें।

3 deque :: initializer सूची संस्करण असाइन करें

पुराने तत्वों को बदलकर नए तत्वों को नए मान प्रदान करें।

4 Deque :: पर

डी में स्थान n पर मौजूद तत्व का संदर्भ देता है ।

5 Deque :: वापस

विराम के अंतिम तत्व का संदर्भ देता है।

6 Deque :: शुरू

डीक के पहले तत्व की ओर इशारा करते हुए एक रैंडम एक्सेस इटरेटर लौटें।

7 Deque :: cbegin

एक निरंतर यादृच्छिक अभिगमकर्ता लौटाता है जो कि deque की शुरुआत की ओर इशारा करता है।

8 Deque :: cend

एक निरंतर यादृच्छिक अभिगमकर्ता लौटाता है जो कि deque की शुरुआत की ओर इशारा करता है।

9 Deque :: स्पष्ट

डीएक से सभी तत्वों को हटाकर डीके को नष्ट कर देता है और डेक्स के आकार को शून्य पर सेट करता है।

10 Deque :: crbegin

एक निरंतर रिवर्स इटरेटर लौटाता है जो कंटेनर की शुरुआत की ओर इशारा करता है।

1 1 Deque :: crend

एक निरंतर रिवर्स पुनरावर्तक लौटाता है जो कि deque के उल्टे सिरे की ओर इशारा करता है।

12 Deque :: क़ायम करना

स्थिति में नए तत्व डालने से कंटेनर का विस्तार होता है ।

13 Deque :: emplace_back

छल के अंत में नया तत्व सम्मिलित करता है।

14 Deque :: emplace_front

छल की शुरुआत में नए तत्व को सम्मिलित करता है।

15 Deque :: खाली

टेस्ट कि रिक्त खाली है या नहीं।

16 Deque :: अंत

एक पुनरावृत्तिकर्ता लौटाता है जो डेक्स कंटेनर में पिछले-अंत तत्व को इंगित करता है।

17 deque :: मिटाएँ स्थिति संस्करण

छल से एकल तत्व निकालता है।

18 deque :: erase रेंज संस्करण

छल से एकल तत्व निकालता है।

19 Deque :: सामने

डेके के पहले तत्व का संदर्भ देता है

20 Deque :: get_allocator

एक आवंटन से संबंधित रिटर्न

21 deque :: एकल तत्व संस्करण डालें

स्थिति में नए तत्व डालने से कंटेनर का विस्तार होता है

22 deque :: इन्सर्ट फिल संस्करण

कंटेनर में नए तत्व डालने से कंटेनर का विस्तार होता है।

23 deque :: इन्सर्ट रेंज संस्करण

कंटेनर में नए तत्व डालने से कंटेनर का विस्तार होता है।

24 deque :: इन्सर्ट मूव वर्जन

कंटेनर में नए तत्व डालने से कंटेनर का विस्तार होता है।

25 deque :: इंसुलेटर सूची संस्करण डालें

कंटेनर में नए तत्व डालने से कंटेनर का विस्तार होता है।

26 Deque :: MAX_SIZE

रिटर्न की अधिकतम संख्या तत्वों को रोक कर रखी जा सकती है।

27 deque :: ऑपरेटर = प्रतिलिपि संस्करण

पुराने को हटाकर नई सामग्री को देवें को सौंपें और यदि आवश्यक हो तो आकार को संशोधित करें।

28 deque :: ऑपरेटर = चाल संस्करण

पुराने को हटाकर नई सामग्री को देवें को सौंपें और यदि आवश्यक हो तो आकार को संशोधित करें।

29 deque :: ऑपरेटर = initializer सूची संस्करण

पुराने को हटाकर नई सामग्री को देवें को सौंपें और यदि आवश्यक हो तो आकार को संशोधित करें।

30 Deque :: ऑपरेटर []

स्थान n पर मौजूद तत्व का संदर्भ देता है ।

31 Deque :: pop_back

पिछले तत्व को deque से निकालता है और एक के बाद एक deque का आकार कम करता है।

32 Deque :: pop_front

पहले तत्व को deque से निकालता है और एक के बाद एक deque का आकार कम करता है।

33 Deque :: push_back

नए तत्व को deque के अंत में सम्मिलित करता है और एक के बाद एक deque का आकार बढ़ाता है।

34 deque :: push_back मूव संस्करण

नए तत्व को deque के अंत में सम्मिलित करता है और एक के बाद एक deque का आकार बढ़ाता है।

35 Deque :: push_front

नए तत्व को deque के सामने रखता है और एक के बाद एक deque का आकार बढ़ाता है।

36 deque :: push_front चाल संस्करण

नए तत्व को deque के सामने रखता है और एक के बाद एक deque का आकार बढ़ाता है।

37 Deque :: rbegin

एक रिवर्स इटरेटर लौटाता है, जो डीके के अंतिम तत्व की ओर इशारा करता है।

38 Deque :: उखड़ना

एक रिवर्स इटरेटर लौटाता है, जो डीके के रिवर्स एंड की ओर इशारा करता है।

39 Deque :: आकार

छल का आकार बदलता है।

40 deque :: मान संस्करण का आकार बदलें

छल का आकार बदलता है।

41 Deque :: shrink_to_fit

कंटेनर को उसके आकार को फिट करने की क्षमता को कम करने का अनुरोध करता है।

42 Deque :: आकार

छल में मौजूद तत्वों की संख्या लौटाता है।

43 Deque :: स्वैप

किसी अन्य deque x की सामग्री के साथ deque की सामग्री को निकालता है ।

गैर-सदस्य अतिभारित कार्य

अनु क्रमांक। विधि और विवरण
1 ऑपरेटर ==

टेस्ट कि क्या दो डेक्स बराबर हैं या नहीं।

2 ऑपरेटर! =

टेस्ट कि क्या दो डेक्स बराबर हैं या नहीं।

3 ऑपरेटर <

टेस्ट कि पहली छल अन्य की तुलना में कम है या नहीं।

4 ऑपरेटर <=

टेस्ट कि पहली छलाँग अन्य की तुलना में कम है या बराबर है या नहीं।

5 ऑपरेटर>

टेस्ट कि क्या पहली छल अन्य की तुलना में अधिक है या नहीं।

6 ऑपरेटर> =

टेस्ट कि क्या पहली छलाँग अन्य की तुलना में अधिक या बराबर है या नहीं।

7 विनिमय

दो deque की सामग्री का आदान प्रदान करता है।