क्विक सॉर्ट

मुक्त ज्ञानकोश विकिपीडिया से
नेविगेशन पर जाएँ खोज पर जाएँ
The printable version is no longer supported and may have rendering errors. Please update your browser bookmarks and please use the default browser print function instead.

क्विक सॉर्ट (Quicksort) आंकड़ों को एक क्रम में लाने वाला (sorting) कलनविधि(अल्गोरिद्म) है। यह मर्ज सॉर्ट की तरह ही एक बांटो और जीतो (डिवाइड ऐण्ड कॉन्कर) एल्गोरिथ्म है। यह दिए गए आंकड़ों में से एक सदस्य को धुरी के रूप में चुनता है और चुने हुए धुरी के चारों ओर दिए गए सरणी को विभाजित करता है। क्विकसॉर्ट के कई अलग-अलग संस्करण हैं जो विभिन्न तरीकों से धुरी उठाते हैं। [१] हमेशा पहले तत्व को पिवट के रूप में चुनें। हमेशा अंतिम तत्व को धुरी के रूप में चुनें (नीचे लागू किया गया) धुरी के रूप में एक यादृच्छिक तत्व चुनें। मध्यिका को धुरी के रूप में चुनें।

क्विक सॉर्ट में प्रमुख प्रक्रिया विभाजन () है। विभाजन का लक्ष्य, एक सरणी और धुरी के रूप में सरणी का एक तत्व x दिया गया है, x को छांटे गए सरणी में अपनी सही स्थिति पर रखें और x से पहले सभी छोटे तत्वों (x से छोटे) को डालें, और बाद में सभी बड़े तत्वों (x से अधिक) को डालें। एक्स। यह सब रैखिक समय में किया जाना चाहिए। [२]

क्विक सॉर्ट के लिए एल्गोरिथम

[३]

algorithm quicksort(A, lo, hi) is
    if lo < hi then
        p := partition(A, lo, hi)
        quicksort(A, lo, p - 1)
        quicksort(A, p + 1, hi)

algorithm partition(A, lo, hi) is
    pivot := A[hi]
    i := lo
    for j := lo to hi do
        if A[j] < pivot then
            swap A[i] with A[j]
            i := i + 1
    swap A[i] with A[hi]
    return i

विभाजन एल्गोरिथम

[४]

विभाजन करने के कई तरीके हो सकते हैं, निम्नलिखित छद्म कोड CLRS पुस्तक में दी गई विधि को अपनाते हैं। तर्क सरल है, हम बाएं तत्व से शुरू करते हैं और छोटे (या बराबर) तत्वों के सूचकांक पर नज़र रखते हैं। ट्रैवर्सिंग करते समय, यदि हमें कोई छोटा तत्व मिलता है, तो हम वर्तमान तत्व को गिरफ्तारी [i] के साथ स्वैप करते हैं। अन्यथा हम वर्तमान तत्व की उपेक्षा करते हैं।

/ * कम -> प्रारंभिक सूचकांक, उच्च -> अंत सूचकांक * / क्विक सॉर्ट (गिरफ्तार [], निम्न, उच्च) {

   यदि (कम <उच्च)
   {
       / * pi इंडेक्स विभाजन कर रहा है, अब [pi] गिरफ्तार है
          सही जगह पर * /
       पी = विभाजन (गिरफ्तारी, कम, उच्च);
       क्विक सॉर्ट (गिरफ्तारी, कम, पीआई - 1); // पी से पहले
       क्विक सॉर्ट (गिरफ्तारी, पीआई + 1, उच्च); // पी के बाद
   }

}

विभाजन का चित्रण ():

गिरफ्तार [] = {१०, 10०, 10०, ३०, ९ ०, ४०, ५०, {०} सूचकांक: 0 1 2 3 4 5 6

कम = 0, उच्च = 6, धुरी = गिरफ्तारी [h] = 70 छोटे तत्व का प्रारंभिक सूचकांक, i = -1

जे = निम्न से उच्च -1 तक के तत्वों का पारगमन j = 0: चूंकि गिरफ्तारी [j] <= pivot, i ++ और swap (गिरफ्तारी [i], गिरफ्तारी [j]) मैं = ० arr [] = {10, 80, 30, 90, 40, 50, 70} // मैं और जम्मू के रूप में कोई परिवर्तन नहीं

j = 1: गिरफ्तारी के बाद से [j]> धुरी, कुछ न करें // I और गिरफ्तारी में कोई बदलाव नहीं []

j = 2: गिरफ्तारी के बाद से [j] <= pivot, i ++ और swap (arr [i], arrest [j]) मैं = १ arr [] = {10, 30, 80, 90, 40, 50, 70} // हम 80 और 30 स्वैप करते हैं

j = 3: चूंकि गिरफ्तारी [j]> धुरी, कुछ भी नहीं // I और गिरफ्तारी में कोई बदलाव नहीं []

j = 4: चूंकि गिरफ्तारी [j] <= pivot, i ++ और swap (गिरफ्तारी [i], गिरफ्तारी [j]) मैं = २ arr [] = {10, 30, 40, 90, 80, 50, 70} // 80 और 40 स्वैप किया गया j = 5: चूंकि गिरफ्तारी [j] <= pivot, i ++ और swap arrest [i] गिरफ्तारी [j] के साथ मैं = ३ arr [] = {10, 30, 40, 50, 80, 90, 70} // 90 और 50 स्वैप

हम लूप से बाहर आते हैं क्योंकि j अब हाई -1 के बराबर है। अंत में हम अदला-बदली करके सही स्थिति में पिवट रखते हैं गिरफ्तार [i + 1] और गिरफ्तार [उच्च] (या धुरी) arr [] = {10, 30, 40, 50, 70, 90, 80} // 80 और 70 Swapped

अब 70 अपने सही स्थान पर है। से छोटे सभी तत्व 70 इससे पहले हैं और 70 से अधिक सभी तत्व बाद में हैं यह।

आवश्यक समय

[५] सबसे खराब स्थिति O(n2), सर्वश्रेष्ठ-स्थिति प्रदर्शन O(n लॉग एन) , (सरल विभाजन) या O (n) (तीन-तरफ़ा विभाजन और समान कुंजियाँ), औसत प्रदर्शन ओ (एन लॉग एन)

सन्दर्भ