सी ++ लाइब्रेरी - <मानचित्र>

मानचित्र का परिचय

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

आमतौर पर तत्वों को सॉर्ट करने के लिए उपयोग किए जाने वाले मैप प्रमुख मानों में। मानचित्र डेटा के लिए कुंजी और मूल्य का प्रकार भिन्न हो सकता है और इसे इस रूप में दर्शाया जाता है

typedef pair<const Key, T> value_type;

मैप्स को आमतौर पर बाइनरी सर्च ट्री के रूप में लागू किया जाता है।

शून्य आकार के नक्शे भी मान्य हैं। उस स्थिति में map.begin () और map.end () एक ही स्थान पर इंगित करता है।

परिभाषा

नीचे std की परिभाषा है: <map> हैडर फ़ाइल से नक्शा

template < class Key,
           class T,
           class Compare = less<Key>,
           class Alloc = allocator<pair<const Key,T> >
           > class map;

मापदंडों

  • Key - कुंजी का प्रकार।

  • T - मैप किए गए मानों का प्रकार।

  • Compare - एक बाइनरी विधेय जो दो तत्व कुंजियों को तर्क के रूप में लेता है और एक बूल लौटाता है।

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

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

सदस्य प्रकार

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

अनु क्रमांक। सदस्य प्रकार परिभाषा
1 मुख्य प्रकार से कुंजी (टेम्पलेट का पहला पैरामीटर)
2 mapped_type टी (टेम्पलेट का दूसरा पैरामीटर)
3 key_compare तुलना (टेम्पलेट के तीसरे पैरामीटर)
4 allocator_type एलोक (टेम्पलेट का चौथा पैरामीटर)
5 मान प्रकार जोड़ी <const key_type, mapped_type>
6 value_compare तत्वों की तुलना करने के लिए नेस्टेड फंक्शन क्लास
7 संदर्भ allocator_type :: संदर्भ
8 const_reference allocator_type :: const_reference
9 सूचक allocator_type :: सूचक
10 const_pointer allocator_type :: const_pointer
1 1 इटरेटर द्वि-दिशात्मक पुनरावृत्ती मान_टाइप करने के लिए
12 const_iterator द्वि-दिशात्मक पुनरावृत्ति const value_type के लिए
13 reverse_iterator रिवर्स इटरेटर
14 const_reverse_iterator निरंतर उल्टा चलने वाला
15 difference_type ptrdiff_t
16 आकार प्रकार size_t

<मानचित्र> से कार्य

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

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

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

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

2 नक्शा :: नक्शा रेंज निर्माता

पहले से लेकर अंतिम तक की सीमा में उतने ही तत्वों के साथ एक मानचित्र बनाता है

3 नक्शा :: नक्शा कॉपी निर्माता

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

4 नक्शा :: नक्शा मूव कंस्ट्रक्टर

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

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

मानचित्र को सूची से आरंभ करता है।

नाशक

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

मेमोरी को नष्ट करके मैप ऑब्जेक्ट को नष्ट कर देता है।

सदस्य कार्य

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

कुंजी के साथ जुड़े मैप किया मूल्य के लिए संदर्भ लौटाता कश्मीर

2 नक्शा :: शुरू

एक पुनरावृत्ति देता है जो नक्शे के पहले तत्व को संदर्भित करता है।

3 नक्शा :: cbegin

एक निरंतर पुनरावृत्ति देता है जो मानचित्र के पहले तत्व को संदर्भित करता है।

4 नक्शा :: cend

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

5 नक्शा :: स्पष्ट

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

6 नक्शा :: गिनती

रिटर्न मैप की कुंजी से संबद्ध मानों की संख्या कश्मीर

7 नक्शा :: crbegin

एक निरंतर रिवर्स इटरेटर लौटाता है जो कंटेनर i के अंतिम तत्व को इंगित करता है।

8 नक्शा :: crend

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

9 नक्शा :: क़ायम करना

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

10 नक्शा :: emplace_hint संकेत संस्करण

तत्व के लिए एक स्थिति के रूप में संकेत का उपयोग करते हुए नक्शे में एक नया तत्व सम्मिलित करता है।

1 1 नक्शा :: खाली

नक्शे खाली हैं या नहीं इसका परीक्षण करें।

12 नक्शा :: अंत

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

13 नक्शा :: equal_range

उन तत्वों की श्रेणी देता है जो विशिष्ट कुंजी से मेल खाते हैं।

14 नक्शा :: स्थिति संस्करण मिटाएँ

नक्शे के एकल तत्व को स्थिति से हटाता है ।

15 नक्शा :: स्थिति संस्करण मिटाएँ

नक्शे के एकल तत्व को स्थिति से हटाता है ।

16 नक्शा :: मिटा कुंजी

मैप की कुंजी से संबद्ध मूल्य निकालता है कश्मीर

17 नक्शा :: मिटा रेंज संस्करण

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

18 नक्शा :: मिटा रेंज संस्करण

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

19 नक्शा :: लगता है

कुंजी के साथ जुड़े एक तत्व ढूँढता है कश्मीर

20 नक्शा :: get_allocator

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

21 नक्शा :: एकल तत्व डालें

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

22 नक्शा :: संकेत संस्करण डालें

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

23 नक्शा :: सम्मिलित रेंज संस्करण

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

24 नक्शा :: सम्मिलित करें संकेत संकेत

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

25 नक्शा :: डालने सूची सूची संस्करण

इनिशिएटिव लिस्ट से नया एलिमेंट डालकर मैप बढ़ाता है।

26 नक्शा :: key_comp

एक फ़ंक्शन ऑब्जेक्ट लौटाता है जो कुंजियों की तुलना करता है, जो इस कंटेनर के निर्माता तर्क COMP की एक प्रति है ।

27 नक्शा :: LOWER_BOUND

पहला तत्व है जो कम नहीं है कुंजी से करने के लिए एक इटरेटर इशारा देता है कश्मीर

28 नक्शा :: MAX_SIZE

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

29 नक्शा :: ऑपरेटर = प्रतिलिपि संस्करण

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

30 नक्शा :: ऑपरेटर = चाल संस्करण

एक मानचित्र की सामग्री को दूसरे में ले जाएं और यदि आवश्यक हो तो आकार को संशोधित करें।

31 नक्शा :: संचालक = इनिशियलाइज़र सूची संस्करण

प्रारंभिक सूची से मानचित्र में तत्वों की प्रतिलिपि बनाएँ।

32 मानचित्र :: ऑपरेटर [] प्रतिलिपि संस्करण

यदि कुंजी k कंटेनर में एक तत्व से मेल खाता है, तो विधि तत्व का संदर्भ देता है।

33 नक्शा :: ऑपरेटर [] चाल संस्करण

यदि कुंजी k कंटेनर में एक तत्व से मेल खाता है, तो विधि तत्व का संदर्भ देता है।

34 नक्शा :: rbegin

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

35 नक्शा :: उखड़ना

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

36 नक़्शे का आकार

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

37 नक्शा :: स्वैप

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

38 नक्शा :: UPPER_BOUND

रिटर्न पुनरावर्तक पहला तत्व है जो कुंजी से अधिक है की ओर इशारा करते कश्मीर

39 नक्शा :: value_comp

एक फ़ंक्शन ऑब्जेक्ट लौटाता है जो कि प्रकार std :: map :: value_type की वस्तुओं की तुलना करता है

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

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

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

2 ऑपरेटर! =

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

3 ऑपरेटर <

टेस्ट कि पहला नक्शा दूसरे से कम है या नहीं।

4 नक्शा :: ऑपरेटर <=

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

5 ऑपरेटर>

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

6 ऑपरेटर> =

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

7 स्वैप ()

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

मल्टीमप का परिचय

मल्टिमैप डेटा संरचना की तरह शब्दकोष है। यह (की, वैल्यू) जोड़ी का एक अनुक्रम है , जहां कई मानों को बराबर कुंजियों के साथ जोड़ा जा सकता है। इसे अक्सर साहचर्य सरणी के रूप में संदर्भित किया जाता है ।

बहुतायत में मुख्य मूल्यों को आमतौर पर तत्वों को सॉर्ट करने के लिए उपयोग किया जाता है। मल्टीमैप डेटा के लिए कुंजी और मूल्य का प्रकार भिन्न हो सकता है और इसे निम्न रूप में दर्शाया जाता है

typedef pair<const Key, T> value_type;

मल्टीपैप को आमतौर पर बाइनरी सर्च ट्री के रूप में लागू किया जाता है।

शून्य आकार के मल्टीपैप भी मान्य हैं। उस स्थिति में multimap.begin () और multimap.end () एक ही स्थान पर इंगित करता है।

परिभाषा

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

template < class Key,
           class T,
           class Compare = less<Key>,
           class Alloc = allocator<pair<const Key,T> >
           > class multimap;

मापदंडों

  • Key - कुंजी का प्रकार।

  • T - मैप किए गए मानों का प्रकार।

  • Compare - एक बाइनरी विधेय जो दो तत्व कुंजियों को तर्क के रूप में लेता है और एक बूल लौटाता है।

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

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

सदस्य प्रकार

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

अनु क्रमांक। सदस्य प्रकार परिभाषा
1 मुख्य प्रकार से कुंजी (टेम्पलेट का पहला पैरामीटर)
2 mapped_type टी (टेम्पलेट का दूसरा पैरामीटर)
3 key_compare तुलना (टेम्पलेट के तीसरे पैरामीटर)
4 allocator_type एलोक (टेम्पलेट का चौथा पैरामीटर)
5 मान प्रकार जोड़ी <const key_type, mapped_type>
6 value_compare तत्वों की तुलना करने के लिए नेस्टेड फंक्शन क्लास
7 संदर्भ allocator_type :: संदर्भ
8 const_reference allocator_type :: const_reference
9 सूचक allocator_type :: सूचक
10 const_pointer allocator_type :: const_pointer
1 1 इटरेटर द्वि-दिशात्मक पुनरावृत्ती मान_टाइप करने के लिए
12 const_iterator द्वि-दिशात्मक पुनरावृत्ति const value_type के लिए
13 reverse_iterator रिवर्स इटरेटर
14 const_reverse_iterator निरंतर उल्टा चलने वाला
15 difference_type ptrdiff_t
16 आकार प्रकार size_t

<मल्टीमैप> से कार्य

नीचे <multimap> शीर्ष लेख से सभी विधियों की सूची दी गई है।

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

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

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

2 मल्टीमैप :: मल्टीमैप रेंज कंस्ट्रक्टर

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

3 मल्टीमैप :: मल्टीमैप कॉपी कंस्ट्रक्टर

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

4 मल्टीमप :: मल्टीमैप मूव कंस्ट्रक्टर

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

5 मल्टीमप :: मल्टीपैप इनिशिएटिव लिस्ट कंस्ट्रक्टर

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

नाशक

अनु क्रमांक। विधि और विवरण
1 मल्टीमैप :: ~ मल्टीमैप

यह मेमोरी डील करके मल्टीमैप ऑब्जेक्ट को नष्ट कर देता है।

सदस्य कार्य

अनु क्रमांक। विधि और विवरण
1 मल्टीमैप :: शुरू

एक पुनरावृत्ति देता है जो मल्टीपैप के पहले तत्व को संदर्भित करता है।

2 मल्टीमैप :: cbegin

एक निरंतर पुनरावृत्ति देता है जो मल्टीमाप के पहले तत्व को संदर्भित करता है।

3 मल्टीमैप :: cend

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

4 मल्टीमैप :: स्पष्ट

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

5 मल्टीमैप :: गिनती

कुंजी के साथ संबद्ध multimapped मूल्यों का रिटर्न संख्या कश्मीर

6 मल्टीमैप :: crbegin

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

7 मल्टीमैप :: crend

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

8 मल्टीमैप :: क़ायम करना

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

9 multimap :: emplace_hint संकेत संस्करण

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

10 मल्टीमैप :: खाली

टेस्ट मल्टीपैप खाली है या नहीं।

1 1 मल्टीमैप :: अंत

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

12 मल्टीमैप :: equal_range

उन तत्वों की श्रेणी देता है जो विशिष्ट कुंजी से मेल खाते हैं।

13 multimap :: स्थिति संस्करण मिटाएँ

मल्टीपैप के एकल तत्व को स्थिति से हटाता है ।

14 multimap :: स्थिति संस्करण मिटाएँ

मल्टीपैप के एकल तत्व को स्थिति से हटाता है ।

15 मल्टीमप :: मिटा कुंजी

मैप की कुंजी से संबद्ध मूल्य निकालता है कश्मीर

16 मल्टीमप :: इरेज़ रेंज संस्करण

मल्टीमप से तत्व की सीमा को हटाता है।

17 मल्टीमप :: इरेज़ रेंज संस्करण

मल्टीमप से तत्व की सीमा को हटाता है।

18 मल्टीमैप :: खोज

कुंजी के साथ जुड़े एक तत्व ढूँढता है कश्मीर

19 मल्टीमैप :: get_allocator

मल्टीमैप से जुड़ा एक एलोकेटर देता है।

20 मल्टीमप :: एकल तत्व डालें

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

21 मल्टीमप :: इन्सर्ट हिंट संस्करण

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

22 मल्टीमप :: इन्सर्ट रेंज वर्जन

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

23 मल्टीमप :: इंसर्ट मूव हिंट सिरिक्शन

नए तत्व को सम्मिलित करके मल्टीमैप बढ़ाता है।

24 multimap :: initializer सूची संस्करण डालें

इनिशिएटिव लिस्ट से नया एलिमेंट डालकर मल्टीमैप बढ़ाता है।

25 मल्टीमैप :: key_comp

एक फ़ंक्शन ऑब्जेक्ट लौटाता है जो कुंजियों की तुलना करता है, जो इस कंटेनर के निर्माता तर्क COMP की एक प्रति है ।

26 मल्टीमैप :: LOWER_BOUND

पहला तत्व है जो कम नहीं है कुंजी से करने के लिए एक इटरेटर इशारा देता है कश्मीर

27 मल्टीमैप :: MAX_SIZE

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

28 मल्टीमैप :: ऑपरेटर = कॉपी संस्करण

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

29 मल्टीमैप :: ऑपरेटर = संस्करण को स्थानांतरित करें

एक मल्टीमैप की सामग्री को दूसरे में ले जाएं और यदि आवश्यक हो तो आकार को संशोधित करें।

30 मल्टीमैप :: ऑपरेटर = आरंभीकरण सूची संस्करण

शुरुआती सूची से तत्वों को कॉपी करके मल्टीमैप करें।

31 मल्टीमैप :: rbegin

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

32 मल्टीमैप :: उखड़ना

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

33 मल्टीमैप :: आकार

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

34 मल्टीमैप :: स्वैप

मल्टीमप एक्स की सामग्री के साथ मल्टीमैप की सामग्री का आदान-प्रदान करता है।

35 मल्टीमैप :: UPPER_BOUND

रिटर्न पुनरावर्तक पहला तत्व है जो कुंजी से अधिक है की ओर इशारा करते कश्मीर

36 मल्टीमैप :: value_comp

एक फ़ंक्शन ऑब्जेक्ट लौटाता है जो कि प्रकार std :: multimap :: value_type की वस्तुओं की तुलना करता है

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

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

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

2 ऑपरेटर! =

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

3 ऑपरेटर <

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

4 मल्टीमैप :: ऑपरेटर <=

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

5 ऑपरेटर>

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

6 ऑपरेटर> =

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

7 स्वैप ()

मल्टीमप एक्स की सामग्री के साथ मल्टीमैप की सामग्री का आदान-प्रदान करता है।