क्विक सॉर्ट और मर्ज सॉर्ट में अंतर

लेखक: Laura McKinney
निर्माण की तारीख: 1 अप्रैल 2021
डेट अपडेट करें: 11 मई 2024
Anonim
क्विक सॉर्ट || Quick Sort in Hindi || Divide and Conquer || DAA || Studies Studio
वीडियो: क्विक सॉर्ट || Quick Sort in Hindi || Divide and Conquer || DAA || Studies Studio

विषय


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

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

    1. तुलना चार्ट
    2. परिभाषा
    3. मुख्य अंतर
    4. निष्कर्ष

तुलना चार्ट

तुलना के लिए आधारजल्दी से सुलझाएंमर्ज़ सॉर्ट
एरे में तत्वों का विभाजनतत्वों की सूची का विभाजन आवश्यक रूप से आधे में विभाजित नहीं है।सरणी को हमेशा आधे (n / 2) में विभाजित किया जाता है।
सबसे खराब मामला जटिलतापर2)ओ (एन लॉग एन)
पर अच्छी तरह से काम करता हैछोटी छोटी सरणीकिसी भी प्रकार के सरणी में ठीक काम करता है।
गतिछोटे डेटा सेट के लिए अन्य छँटाई एल्गोरिदम की तुलना में तेज़।सभी प्रकार के डेटा सेटों में लगातार गति।
अतिरिक्त भंडारण स्थान की आवश्यकताकमअधिक
दक्षताबड़े सरणियों के लिए अक्षम। अधिक कुशल।
छँटाई विधिअंदर काबाहरी


क्विक सॉर्ट की परिभाषा

जल्दी से सुलझाएं व्यापक रूप से एल्गोरिथ्म का उपयोग किया जाता है क्योंकि यह लघु सरणियों के लिए तेज़ होता है। तत्वों के सेट को बार-बार भागों में विभाजित किया जाता है जब तक कि इसे आगे विभाजित करना संभव न हो। त्वरित प्रकार के रूप में भी जाना जाता है विभाजन विनिमय प्रकार। यह तत्वों के विभाजन के लिए एक प्रमुख तत्व (धुरी के रूप में जाना जाता है) का उपयोग करता है। एक विभाजन में वे तत्व होते हैं जो प्रमुख तत्व से छोटे होते हैं। एक अन्य विभाजन में वे तत्व शामिल हैं जो प्रमुख तत्व से अधिक हैं। तत्वों को पुनरावर्ती रूप से क्रमबद्ध किया जाता है।

मान लीजिए कि एक सरणी A, A, A, …… .., A की n संख्या है जिसे क्रमबद्ध किया जाना है। त्वरित सॉर्ट एल्गोरिथ्म में निम्नलिखित चरण शामिल थे।

  1. पहला तत्व या कुंजी के रूप में चुना गया कोई भी यादृच्छिक तत्व, मान = A (1)।
  2. "कम" पॉइंटर को दूसरे स्थान पर रखा गया है और "अप" पॉइंटर को एरे के अंतिम तत्व पर रखा गया है, अर्थात् कम = 2 और अप = एन;
  3. लगातार, एक स्थिति तक "कम" सूचक को बढ़ाएँ (ए> कुंजी)।
  4. लगातार, एक स्थिति तक "अप" पॉइंटर को अपग्रेड करें (ए <= कुंजी)।
  5. यदि ऊपर A के साथ कम इंटरचेंज A से अधिक है।
  6. चरण 3,4 और 5 को तब तक दोहराएं जब तक कि चरण 5 में स्थिति विफल नहीं हो जाती (यानी ऊपर <= कम) तब कुंजी के साथ ए का विनिमय करें।
  7. यदि कुंजी के बचे हुए तत्व कुंजी से छोटे हैं और कुंजी के सही तत्व कुंजी से अधिक हैं, तो सरणी को दो उप-सरणियों में विभाजित किया गया है।
  8. उपरोक्त प्रक्रिया बार-बार सबरेज़ पर लागू होती है जब तक कि संपूर्ण सरणी को सॉर्ट नहीं किया जाता है।


फायदे और नुकसान

इसमें एक अच्छा औसत व्यवहार होता है। क्विक सॉर्ट की रनिंग टाइम जटिलता अच्छी है कि यह एल्गोरिदम जैसे बबल सॉर्ट, इंसर्शन सॉर्ट और सिलेक्शन सॉर्ट से तेज है। हालांकि, यह जटिल और बहुत पुनरावर्ती है, यही कारण है कि यह बड़े सरणियों के लिए उपयुक्त नहीं है।

मर्ज सॉर्ट की परिभाषा

मर्ज़ सॉर्ट एक बाहरी एल्गोरिथ्म है जो विभाजन और रणनीति पर आधारित है। तत्वों को उप-सरणियों (n / 2) में बार-बार विभाजित किया जाता है जब तक कि केवल एक तत्व नहीं छोड़ा जाता है, जो क्रमबद्ध समय को काफी कम कर देता है। यह सहायक सरणी के भंडारण के लिए अतिरिक्त भंडारण का उपयोग करता है। मर्ज सॉर्ट तीन सरणियों का उपयोग करता है जहां दो का उपयोग प्रत्येक आधे को संग्रहीत करने के लिए किया जाता है, और तीसरे एक का उपयोग अंतिम सॉर्ट की गई सूची को संग्रहीत करने के लिए किया जाता है। प्रत्येक सरणी को पुनरावर्ती रूप से सॉर्ट किया जाता है। अंत में, यह सरणी के n तत्व का आकार बनाने के लिए सबरेज़ को मर्ज किया जाता है। सूची हमेशा त्वरित क्रमबद्ध करने के लिए सिर्फ आधे (n / 2) प्रसार में विभाजित है।

बता दें कि A, A, A,…, ………, A की संख्या के तत्वों की सरणी है। मर्ज दिए गए चरणों का अनुसरण करता है।

  1. सरणी ए को लगभग n / 2 में विभाजित करके उप-सरणी को 2 से विभाजित करें, जिसका अर्थ है कि (ए, ए), (ए), ए (ए), ए (ए), (ए, ए) उप-सरणियों के तत्वों को उप-सरणियों में होना चाहिए क्रमबद्ध क्रम में हो।
  2. आकार 4 के क्रमबद्ध उपप्रकारों की सूची प्राप्त करने के लिए प्रत्येक जोड़े के जोड़े को मिलाएं; तत्वों में तत्व भी क्रमबद्ध क्रम में होते हैं, (ए, ए, ए), ..., ..., (ए, ए, ए), ..., ..., (ए, ए, ए, ए)।
  3. चरण 2 को बार-बार किया जाता है जब तक कि आकार n का केवल एक छांटा गया सरणी न हो।

फायदे और नुकसान

मर्ज सॉर्ट एल्गोरिथ्म छँटाई में शामिल तत्वों की संख्या की परवाह किए बिना सटीक और सटीक तरीके से करता है। यह बड़े डेटा सेट के साथ भी ठीक काम करता है। हालाँकि, यह मेमोरी के बड़े हिस्से की खपत करता है।

  1. मर्ज सॉर्ट में, सरणी को केवल दो हिस्सों (यानी n / 2) में विभाजित किया जाना चाहिए। जैसा कि, त्वरित प्रकार में, सूची को समान तत्वों में विभाजित करने की कोई अनिवार्यता नहीं है।
  2. त्वरित सॉर्ट की सबसे खराब स्थिति जटिलता O (n) है2) क्योंकि यह सबसे खराब स्थिति में बहुत अधिक तुलना करता है। इसके विपरीत, मर्ज सॉर्ट में एक ही सबसे खराब स्थिति और औसत केस जटिलताएं होती हैं, वह है ओ (एन लॉग एन)।
  3. मर्ज सॉर्ट किसी भी प्रकार के डेटा सेट पर अच्छी तरह से काम कर सकता है चाहे वह बड़ा हो या छोटा। इसके विपरीत, त्वरित सॉर्ट बड़े डेटासेट के साथ अच्छी तरह से काम नहीं कर सकता है।
  4. त्वरित सॉर्ट कुछ मामलों में मर्ज सॉर्ट की तुलना में तेज़ है जैसे कि छोटे डेटा सेट के लिए।
  5. मर्ज सॉर्ट के लिए सहायक सरणियों को संग्रहीत करने के लिए अतिरिक्त मेमोरी स्पेस की आवश्यकता होती है। दूसरी ओर, त्वरित संग्रहण में अतिरिक्त संग्रहण के लिए अधिक स्थान की आवश्यकता नहीं होती है।
  6. त्वरित सॉर्ट की तुलना में मर्ज सॉर्ट अधिक कुशल है।
  7. त्वरित सॉर्ट आंतरिक सॉर्टिंग विधि है जहां डेटा को सॉर्ट करना है जो मुख्य मेमोरी में एक समय में समायोजित किया जाता है। इसके विपरीत, मर्ज सॉर्ट बाहरी सॉर्टिंग विधि है जिसमें डेटा को सॉर्ट किया जाना है और एक ही समय में मेमोरी में समायोजित नहीं किया जा सकता है और कुछ को सहायक मेमोरी में रखा जाना चाहिए।

निष्कर्ष

त्वरित सॉर्ट तेजी से मामले हैं, लेकिन कुछ स्थितियों में अक्षम है और मर्ज सॉर्ट की तुलना में बहुत अधिक तुलना करता है। हालांकि मर्ज सॉर्ट के लिए कम तुलना की आवश्यकता होती है, इसे अतिरिक्त सरणी को संग्रहीत करने के लिए 0 (n) के अतिरिक्त मेमोरी स्पेस की आवश्यकता होती है जबकि त्वरित सॉर्ट में O (लॉग एन) के स्थान की आवश्यकता होती है।