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

परिचय

सूची एक लोकप्रिय रूप से प्रयुक्त अनुक्रम कंटेनर है। कंटेनर एक ऐसी वस्तु है जो एक ही प्रकार का डेटा रखती है। सूची कंटेनर को दोगुनी लिंक-सूची के रूप में कार्यान्वित किया जाता है, इसलिए यह डेटा के लिए द्विदिश अनुक्रमिक पहुंच प्रदान करता है।

सूची तेजी से यादृच्छिक पहुँच प्रदान नहीं करती है, यह केवल दोनों दिशाओं में अनुक्रमिक पहुँच का समर्थन करती है। सूची निरंतर समय में एक अनुक्रम के भीतर कहीं भी सम्मिलन और विलोपन ऑपरेशन की अनुमति देती है।

सूची के तत्व स्मृति के विभिन्न विखंडू में बिखरे हुए हो सकते हैं। कंटेनर आवश्यक जानकारी संग्रहीत करता है ताकि यह डेटा तक अनुक्रमिक पहुंच की अनुमति दे सके। रन टाइम पर दोनों सिरों से सूची आवश्यकतानुसार सिकुड़ या विस्तारित हो सकती है। भंडारण की आवश्यकता आंतरिक आवंटनकर्ता द्वारा स्वचालित रूप से पूरी की जाती है।

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

परिभाषा

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

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

मापदंडों

  • 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

<सूची> से कार्य

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

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

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

शून्य तत्वों के साथ एक खाली सूची का निर्माण करता है।

2 सूची :: सूची निर्माणकर्ता भरें

N तत्वों के साथ एक नई सूची बनाता है और सूची के प्रत्येक तत्व को वैल असाइन करता है ।

3 सूची :: सूची निर्माणकर्ता भरें

N तत्वों के साथ एक नई सूची बनाता है और सूची के प्रत्येक तत्व को शून्य मान प्रदान करता है।

4 सूची :: सूची श्रेणी निर्माणकर्ता

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

5 सूची :: सूची कॉपी निर्माता

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

6 सूची :: सूची चाल निर्माण निर्माता

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

7 सूची :: सूची आरम्भिक सूची निर्माणकर्ता

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

नाशक

अनु क्रमांक। विधि और विवरण
1 सूची :: ~ सूची

सूची ऑब्जेक्ट को नष्ट करके नष्ट कर देता है यह मेमोरी है।

सदस्य कार्य

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

पुराने को बदलकर सूची में नए मान निर्दिष्ट करता है।

2 सूची :: संस्करण भरें असाइन करें

पुराने को बदलकर सूची में नए मान निर्दिष्ट करता है।

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

पुराने को बदलकर सूची में नए मान निर्दिष्ट करता है।

4 सूची :: वापस

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

5 सूची :: शुरू

एक यादृच्छिक पहुँच पुनरावृत्ति देता है जो सूची के पहले तत्व को इंगित करता है।

6 सूची :: cbegin

एक निरंतर यादृच्छिक एक्सेसरी लौटाता है जो सूची की शुरुआत की ओर इशारा करता है।

7 सूची :: cend

एक निरंतर यादृच्छिक अभिगमकर्ता लौटाता है जो सूची के अंत में इंगित करता है।

8 सूची :: स्पष्ट

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

9 सूची :: crbegin

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

10 सूची :: crend

एक निरंतर रिवर्स पुनरावृत्ति लौटाता है जो सूची में पहले तत्व से पहले सैद्धांतिक तत्व को इंगित करता है।

1 1 सूची :: क़ायम करना

किसी दिए गए स्थान पर नए तत्व को सम्मिलित करके सूची का विस्तार करता है।

12 सूची :: emplace_back

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

13 सूची :: emplace_front

सूची की शुरुआत में नए तत्व सम्मिलित करता है और एक-एक करके सूची का आकार बढ़ाता है।

14 सूची :: खाली

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

15 सूची :: अंत

एक यादृच्छिक पहुँच पुनरावृत्ति देता है जो सूची के अंतिम तत्व को इंगित करता है।

16 सूची :: मिटाएँ स्थिति संस्करण

सूची से एकल तत्व निकालता है।

17 सूची :: मिटा रेंज संस्करण

सूची से तत्व की श्रेणी निकालता है।

18 सूची :: सामने

सूची के पहले तत्व का संदर्भ देता है।

19 सूची :: get_allocator

सूची से जुड़े एक आवंटनकर्ता को लौटाता है

20 सूची :: एकल तत्व संस्करण डालें

पर नए तत्व डालने से इटरेटर का विस्तार स्थिति सूची में।

21 सूची :: भरने के संस्करण डालें

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

22 सूची :: रेंज संस्करण डालें

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

23 सूची :: प्रविष्टि संस्करण डालें

कंटेनर में नया तत्व डालकर सूची का विस्तार करता है।

24 सूची :: इंसुलेटर सूची सूची डालें

कंटेनर में नए तत्वों को सम्मिलित करके सूची का विस्तार करता है

25 सूची :: MAX_SIZE

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

26 सूची :: मर्ज

एक में दो क्रमबद्ध सूचियों को जोड़ता है।

27 सूची :: मर्ज फंक्शन की तुलना करें

एक में दो क्रमबद्ध सूचियों को जोड़ता है।

28 सूची :: मर्ज चाल संस्करण

चाल शब्दार्थों का उपयोग करके एक में दो क्रमबद्ध सूचियों को जोड़ता है।

29 सूची :: मर्ज फंक्शन मूव वर्जन की तुलना करें

चाल शब्दार्थों का उपयोग करके एक में दो क्रमबद्ध सूचियों को जोड़ता है।

30 सूची :: ऑपरेटर = प्रतिलिपि संस्करण

पुराने को बदलकर सूची में नई सामग्री असाइन करता है।

31 सूची :: ऑपरेटर = चाल संस्करण

पुराने को बदलकर सूची में नई सामग्री निर्दिष्ट करें।

32 सूची :: ऑपरेटर = आरंभीकरण सूची संस्करण

पुराने को बदलकर सूची में नई सामग्री निर्दिष्ट करें।

33 सूची :: pop_back

सूची से अंतिम तत्व निकालता है।

34 सूची :: pop_front

सूची से पहला तत्व निकालता है।

35 सूची :: push_back

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

36 सूची :: पुश_बैक चाल संस्करण

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

37 सूची :: push_front

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

38 सूची :: पुश_फ्रंट चाल संस्करण

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

39 सूची :: rbegin

एक रिवर्स पुनरावृत्ति देता है जो सूची के अंतिम तत्व की ओर इशारा करता है।

40 सूची :: निकालें

उस तत्व से सूची निकालता है जो मूल्य से मेल खाता है।

41 सूची :: remove_if

तत्वों को सूची से हटाता है जो शर्त को पूरा करता है।

42 सूची :: उखड़ना

एक रिवर्स पुनरावृत्ति देता है जो सूची के रिवर्स छोर की ओर इशारा करता है।

43 सूची :: आकार

सूची का आकार बदलता है।

44 सूची :: मान संस्करण का आकार बदलें

सूची का आकार बदलता है।

45 सूची :: रिवर्स

सूची में मौजूद तत्वों के क्रम को उलट देता है।

46 सूची :: आकार

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

47 सूची :: प्रकार

सूची के तत्वों को सॉर्ट करता है।

48 सूची :: प्रकार तुलना समारोह

सूची के तत्वों को सॉर्ट करता है।

49 सूची :: जोड़

सूची से सभी तत्वों को यह * स्थानांतरित करता है।

50 सूची :: विभाजन एकल तत्व

किसी तत्व द्वारा सूची i से x में भेजे गए तत्व को * इस में स्थानांतरित करता है ।

51 सूची :: ब्याह चाल संस्करण

सभी तत्वों को सूची x से * तक ले जाएँ।

52 सूची :: ब्याह रेंज संस्करण

स्थानांतरण की सीमा में तत्व पहले करने के लिए पिछले से एक्स के लिए * यह

53 सूची :: विभाजन एकल तत्व चाल संस्करण

स्थानांतरण तत्व को इटरेटर द्वारा बताया मैं से सूची एक्स में * इस कदम अर्थ विज्ञान का उपयोग करके।

54 सूची :: ब्याह रेंज और चाल संस्करण

स्थानांतरण की सीमा में तत्व पहले करने के लिए पिछले से एक्स के लिए * इस कदम अर्थ विज्ञान का उपयोग करके।

55 सूची :: स्वैप

अन्य सूची x की सामग्री के साथ सूची की सामग्री का आदान-प्रदान करता है ।

56 सूची :: अद्वितीय

सूची से लगातार सभी डुप्लिकेट तत्वों को निकालता है।

57 सूची :: अद्वितीय

सूची से लगातार सभी डुप्लिकेट तत्वों को निकालता है।

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

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

परीक्षण कि क्या दो सूचियाँ समान हैं या नहीं।

2 ऑपरेटर! =

परीक्षण कि क्या दो सूचियाँ समान हैं या नहीं।

3 ऑपरेटर <

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

4 ऑपरेटर <=

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

5 ऑपरेटर>

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

6 ऑपरेटर> =

परीक्षण कि क्या पहली सूची अन्य की तुलना में अधिक या बराबर है या नहीं।

7 विनिमय

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