रेडिक्स हीप: Difference between revisions
m (Deepak moved page मूलांक ढेर to रेडिक्स हीप without leaving a redirect) |
No edit summary |
||
| Line 1: | Line 1: | ||
रेडिक्स हीप [[मोनोटोन प्राथमिकता कतार]] के संचालन को साकार करने के लिए [[डेटा संरचना]] है। तत्वों का सेट जिसके लिए कुंजी सौंपी गई है, उसे प्रबंधित किया जा सकता है। संचालन का रन टाइम सबसे बड़ी और सबसे छोटी कुंजी या स्थिरांक के बीच के अंतर पर निर्भर करता है। डेटा संरचना में मुख्य रूप से बकेट की श्रृंखला होती है, जिसका आकार तेजी से बढ़ता है। | |||
रेडिक्स हीप | |||
==आवश्यकताएँ== | ==आवश्यकताएँ== | ||
| Line 19: | Line 17: | ||
# <math>u[0] = 0, u[1] = u[0] + 1, u[B] = \infty</math> और <math>0 \le u[i+1]-u[i] \le 2^{i-1}</math> के लिए <math>i = 1, \ldots, B-1</math>: बाल्टियों का आकार तेजी से बढ़ता है। | # <math>u[0] = 0, u[1] = u[0] + 1, u[B] = \infty</math> और <math>0 \le u[i+1]-u[i] \le 2^{i-1}</math> के लिए <math>i = 1, \ldots, B-1</math>: बाल्टियों का आकार तेजी से बढ़ता है। | ||
सीमाओं की घातीय वृद्धि (और इस प्रकार | सीमाओं की घातीय वृद्धि (और इस प्रकार बाल्टी की सीमा) पर ध्यान देना महत्वपूर्ण है। इस प्रकार फ़ील्ड मात्राओं की लघुगणकीय निर्भरता मान C की होती है, जो दो प्रमुख मानों के बीच अधिकतम अंतर है। | ||
==संचालन== | ==संचालन== | ||
| Line 25: | Line 23: | ||
आरंभीकरण के दौरान, खाली बकेट और निचली सीमाएं उत्पन्न होती हैं <math>u</math> उत्पन्न होते हैं (अपरिवर्तनीय 2 के अनुसार); कार्यकारी समय <math>O(B)</math>. | आरंभीकरण के दौरान, खाली बकेट और निचली सीमाएं उत्पन्न होती हैं <math>u</math> उत्पन्न होते हैं (अपरिवर्तनीय 2 के अनुसार); कार्यकारी समय <math>O(B)</math>. | ||
सम्मिलित करते समय, | सम्मिलित करते समय, नया तत्व <math>x</math> बाल्टियों और नए तत्व के माध्यम से रैखिक रूप से दाएं से बाएं ओर ले जाया जाता है <math>k(x)</math> उसके बायीं ओर की बाल्टी में संग्रहित किया जाता है <math>u[i] \ge k(x)</math>; कार्यकारी समय <math>O(B)</math>. | ||
कमी-कुंजी के लिए, पहले कुंजी मान घटाया जाता है (अपरिवर्तनीयों के अनुपालन की जाँच करना)। फिर <math>bNum</math> फ़ील्ड का उपयोग तत्व का पता लगाने के लिए किया जाता है और यदि आवश्यक हो, तो इसे सम्मिलित ऑपरेशन के अनुरूप बाईं ओर दोहराया जाता है। चलने का समय है <math>O(1)</math> (परिशोधन)। | कमी-कुंजी के लिए, पहले कुंजी मान घटाया जाता है (अपरिवर्तनीयों के अनुपालन की जाँच करना)। फिर <math>bNum</math> फ़ील्ड का उपयोग तत्व का पता लगाने के लिए किया जाता है और यदि आवश्यक हो, तो इसे सम्मिलित ऑपरेशन के अनुरूप बाईं ओर दोहराया जाता है। चलने का समय है <math>O(1)</math> (परिशोधन)। | ||
एक्सट्रेक्ट-मिन ऑपरेशन बकेट से | एक्सट्रेक्ट-मिन ऑपरेशन बकेट से तत्व को हटा देता है <math>b[0]</math> और उसे वापस कर देता है. यदि बाल्टी <math>b[0]</math> अभी तक खाली नहीं है, कार्रवाई समाप्त हो गई है। यदि, तथापि, यह खाली है, तो अगली बड़ी गैर-रिक्त बाल्टी की खोज की जाती है, जो इसका सबसे छोटा तत्व है <math>k</math> ट्रैक किया गया और <math>u[0]</math> k पर सेट है (इसके लिए नीरसता आवश्यक है)। फिर, अपरिवर्तनीयों के अनुसार, बाल्टी की सीमाओं को फिर से परिभाषित किया जाता है और तत्वों को हटा दिया जाता है <math>b[i]</math> नवगठित बाल्टियों के लिए; कार्यकारी समय <math>O(1)</math> (परिशोधन)। | ||
यदि प्रदर्शित हो, तो फ़ील्ड <math>bNum</math> यह अद्यतित है। | यदि प्रदर्शित हो, तो फ़ील्ड <math>bNum</math> यह अद्यतित है। | ||
Revision as of 21:35, 21 July 2023
रेडिक्स हीप मोनोटोन प्राथमिकता कतार के संचालन को साकार करने के लिए डेटा संरचना है। तत्वों का सेट जिसके लिए कुंजी सौंपी गई है, उसे प्रबंधित किया जा सकता है। संचालन का रन टाइम सबसे बड़ी और सबसे छोटी कुंजी या स्थिरांक के बीच के अंतर पर निर्भर करता है। डेटा संरचना में मुख्य रूप से बकेट की श्रृंखला होती है, जिसका आकार तेजी से बढ़ता है।
आवश्यकताएँ
- सभी कुंजियाँ प्राकृतिक संख्याएँ हैं;
- अधिकतम. कुंजी - न्यूनतम. चाबी स्थिरांक C के लिए C;
- हीप_(डेटा_स्ट्रक्चर)#ऑपरेशंस|एक्सट्रैक्ट-मिन ऑपरेशन मोनोटोनिक है; अर्थात्, क्रमिक एक्स्ट्रैक्ट-मिन कॉल्स द्वारा लौटाए गए मान एकरस रूप से बढ़ रहे हैं।
डेटा संरचना का विवरण
तीन सबसे महत्वपूर्ण क्षेत्र (कंप्यूटर विज्ञान) हैं:
- आकार का , न्यूनतम सूचकांक के रूप में 0 के साथ, बाल्टियाँ संग्रहीत करता है;
- आकार का , न्यूनतम सूचकांक के रूप में 0 के साथ, बाल्टियों की (निचली) सीमाओं को संग्रहीत करें;
- , प्रत्येक तत्व के लिए धारण करता है ढेर में वह बाल्टी जिसमें वह संग्रहीत है।
File:RadixHeap1.pngउपरोक्त चित्र डेटा संरचना को दर्शाता है। निम्नलिखित अपरिवर्तनीय लागू होते हैं:
- में कुंजी : अंदर की चाबियाँ में मान के माध्यम से ऊपर या नीचे होते हैं या सीमित।
- और के लिए : बाल्टियों का आकार तेजी से बढ़ता है।
सीमाओं की घातीय वृद्धि (और इस प्रकार बाल्टी की सीमा) पर ध्यान देना महत्वपूर्ण है। इस प्रकार फ़ील्ड मात्राओं की लघुगणकीय निर्भरता मान C की होती है, जो दो प्रमुख मानों के बीच अधिकतम अंतर है।
संचालन
आरंभीकरण के दौरान, खाली बकेट और निचली सीमाएं उत्पन्न होती हैं उत्पन्न होते हैं (अपरिवर्तनीय 2 के अनुसार); कार्यकारी समय .
सम्मिलित करते समय, नया तत्व बाल्टियों और नए तत्व के माध्यम से रैखिक रूप से दाएं से बाएं ओर ले जाया जाता है उसके बायीं ओर की बाल्टी में संग्रहित किया जाता है ; कार्यकारी समय .
कमी-कुंजी के लिए, पहले कुंजी मान घटाया जाता है (अपरिवर्तनीयों के अनुपालन की जाँच करना)। फिर फ़ील्ड का उपयोग तत्व का पता लगाने के लिए किया जाता है और यदि आवश्यक हो, तो इसे सम्मिलित ऑपरेशन के अनुरूप बाईं ओर दोहराया जाता है। चलने का समय है (परिशोधन)।
एक्सट्रेक्ट-मिन ऑपरेशन बकेट से तत्व को हटा देता है और उसे वापस कर देता है. यदि बाल्टी अभी तक खाली नहीं है, कार्रवाई समाप्त हो गई है। यदि, तथापि, यह खाली है, तो अगली बड़ी गैर-रिक्त बाल्टी की खोज की जाती है, जो इसका सबसे छोटा तत्व है ट्रैक किया गया और k पर सेट है (इसके लिए नीरसता आवश्यक है)। फिर, अपरिवर्तनीयों के अनुसार, बाल्टी की सीमाओं को फिर से परिभाषित किया जाता है और तत्वों को हटा दिया जाता है नवगठित बाल्टियों के लिए; कार्यकारी समय (परिशोधन)।
यदि प्रदर्शित हो, तो फ़ील्ड यह अद्यतित है।
संदर्भ
- B.V. Cherkassky, A.V. Goldberg, C. Silverstein: Buckets, Heaps, Lists and Monotone Priority Queues (Abstract), in: Proceedings of the Eight Annual ACM-SIAM Symposium on Discrete Algorithms. January 1997, pp. 83-92.