रेडिक्स हीप

From Vigyanwiki
Revision as of 21:35, 21 July 2023 by alpha>Akriti

रेडिक्स हीप मोनोटोन प्राथमिकता कतार के संचालन को साकार करने के लिए डेटा संरचना है। तत्वों का सेट जिसके लिए कुंजी सौंपी गई है, उसे प्रबंधित किया जा सकता है। संचालन का रन टाइम सबसे बड़ी और सबसे छोटी कुंजी या स्थिरांक के बीच के अंतर पर निर्भर करता है। डेटा संरचना में मुख्य रूप से बकेट की श्रृंखला होती है, जिसका आकार तेजी से बढ़ता है।

आवश्यकताएँ

  1. सभी कुंजियाँ प्राकृतिक संख्याएँ हैं;
  2. अधिकतम. कुंजी - न्यूनतम. चाबी स्थिरांक C के लिए C;
  3. हीप_(डेटा_स्ट्रक्चर)#ऑपरेशंस|एक्सट्रैक्ट-मिन ऑपरेशन मोनोटोनिक है; अर्थात्, क्रमिक एक्स्ट्रैक्ट-मिन कॉल्स द्वारा लौटाए गए मान एकरस रूप से बढ़ रहे हैं।

डेटा संरचना का विवरण

तीन सबसे महत्वपूर्ण क्षेत्र (कंप्यूटर विज्ञान) हैं:

  1. आकार का , न्यूनतम सूचकांक के रूप में 0 के साथ, बाल्टियाँ संग्रहीत करता है;
  2. आकार का , न्यूनतम सूचकांक के रूप में 0 के साथ, बाल्टियों की (निचली) सीमाओं को संग्रहीत करें;
  3. , प्रत्येक तत्व के लिए धारण करता है ढेर में वह बाल्टी जिसमें वह संग्रहीत है।

File:RadixHeap1.pngउपरोक्त चित्र डेटा संरचना को दर्शाता है। निम्नलिखित अपरिवर्तनीय लागू होते हैं:

  1. में कुंजी : अंदर की चाबियाँ में मान के माध्यम से ऊपर या नीचे होते हैं या सीमित।
  2. और के लिए : बाल्टियों का आकार तेजी से बढ़ता है।

सीमाओं की घातीय वृद्धि (और इस प्रकार बाल्टी की सीमा) पर ध्यान देना महत्वपूर्ण है। इस प्रकार फ़ील्ड मात्राओं की लघुगणकीय निर्भरता मान C की होती है, जो दो प्रमुख मानों के बीच अधिकतम अंतर है।

संचालन

आरंभीकरण के दौरान, खाली बकेट और निचली सीमाएं उत्पन्न होती हैं उत्पन्न होते हैं (अपरिवर्तनीय 2 के अनुसार); कार्यकारी समय .

सम्मिलित करते समय, नया तत्व बाल्टियों और नए तत्व के माध्यम से रैखिक रूप से दाएं से बाएं ओर ले जाया जाता है उसके बायीं ओर की बाल्टी में संग्रहित किया जाता है ; कार्यकारी समय .

कमी-कुंजी के लिए, पहले कुंजी मान घटाया जाता है (अपरिवर्तनीयों के अनुपालन की जाँच करना)। फिर फ़ील्ड का उपयोग तत्व का पता लगाने के लिए किया जाता है और यदि आवश्यक हो, तो इसे सम्मिलित ऑपरेशन के अनुरूप बाईं ओर दोहराया जाता है। चलने का समय है (परिशोधन)।

एक्सट्रेक्ट-मिन ऑपरेशन बकेट से तत्व को हटा देता है और उसे वापस कर देता है. यदि बाल्टी अभी तक खाली नहीं है, कार्रवाई समाप्त हो गई है। यदि, तथापि, यह खाली है, तो अगली बड़ी गैर-रिक्त बाल्टी की खोज की जाती है, जो इसका सबसे छोटा तत्व है ट्रैक किया गया और k पर सेट है (इसके लिए नीरसता आवश्यक है)। फिर, अपरिवर्तनीयों के अनुसार, बाल्टी की सीमाओं को फिर से परिभाषित किया जाता है और तत्वों को हटा दिया जाता है नवगठित बाल्टियों के लिए; कार्यकारी समय (परिशोधन)।

यदि प्रदर्शित हो, तो फ़ील्ड यह अद्यतित है।

संदर्भ