डेटा संरचना और एल्गोरिदम चयन सॉर्ट

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

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

यह एल्गोरिथ्म बड़े डेटा सेट के लिए उपयुक्त नहीं है क्योंकि इसकी औसत और सबसे खराब स्थिति जटिलताएं n (n 2 ) की हैं, जहांn मदों की संख्या है।

चयन कैसे कार्य करता है?

एक उदाहरण के रूप में निम्नलिखित चित्रित सरणी पर विचार करें।

क्रमबद्ध सूची में पहले स्थान के लिए, पूरी सूची क्रमिक रूप से स्कैन की जाती है। पहली स्थिति जहां 14 वर्तमान में संग्रहीत है, हम पूरी सूची खोजते हैं और पाते हैं कि 10 सबसे कम मूल्य है।

इसलिए हम 14 को 10. के साथ प्रतिस्थापित करते हैं। एक पुनरावृत्ति 10 के बाद, जो सूची में न्यूनतम मान होता है, क्रमबद्ध सूची की पहली स्थिति में दिखाई देता है।

दूसरी स्थिति के लिए, जहां 33 निवास कर रहा है, हम बाकी की सूची को रैखिक तरीके से स्कैन करना शुरू करते हैं।

हम पाते हैं कि 14 सूची में दूसरा सबसे कम मूल्य है और इसे दूसरे स्थान पर दिखाई देना चाहिए। हम इन मूल्यों की अदला-बदली करते हैं।

दो पुनरावृत्तियों के बाद, क्रमबद्ध तरीके से शुरुआत में दो न्यूनतम मान तैनात किए जाते हैं।

सरणी में शेष वस्तुओं पर भी यही प्रक्रिया लागू होती है।

निम्नलिखित पूरी छँटाई प्रक्रिया का एक चित्रण चित्रण है -

अब, हम चयन प्रकार के कुछ प्रोग्रामिंग पहलुओं को सीखते हैं।

कलन विधि

Step 1 − Set MIN to location 0
Step 2 − Search the minimum element in the list
Step 3 − Swap with value at location MIN
Step 4 − Increment MIN to point to next element
Step 5 − Repeat until list is sorted

स्यूडोकोड

procedure selection sort 
   list  : array of items
   n     : size of list

   for i = 1 to n - 1
   /* set current element as minimum*/
      min = i    
  
      /* check the element to be minimum */

      for j = i+1 to n 
         if list[j] < list[min] then
            min = j;
         end if
      end for

      /* swap the minimum element with the current element*/
      if indexMin != i  then
         swap list[min] and list[i]
      end if
   end for
	
end procedure

सी प्रोग्रामिंग भाषा में चयन प्रकार कार्यान्वयन के बारे में जानने के लिए, कृपया यहां क्लिक करें ।