डेटा संरचना - बबल सॉर्ट एल्गोरिथम
बबल सॉर्ट एक साधारण सॉर्टिंग एल्गोरिथ्म है। यह छँटाई एल्गोरिथ्म तुलना-आधारित एल्गोरिथ्म है जिसमें आसन्न तत्वों की प्रत्येक जोड़ी की तुलना की जाती है और यदि वे क्रम में नहीं हैं, तो तत्वों की अदला-बदली की जाती है। यह एल्गोरिथ्म बड़े डेटा सेट के लिए उपयुक्त नहीं है क्योंकि इसकी औसत और सबसे खराब स्थिति जटिलता n (n 2 ) की हैn मदों की संख्या है।
बुलबुला कैसे काम करता है?
हम अपने उदाहरण के लिए एक अनसुलझा सरणी लेते हैं। बबल सॉर्ट में it (n 2 ) समय लगता है इसलिए हम इसे छोटा और सटीक रख रहे हैं।
बबल सॉर्ट पहले दो तत्वों के साथ शुरू होता है, उनकी तुलना करके यह जांचने के लिए कि कौन अधिक है।
इस स्थिति में, मान 33 14 से अधिक है, इसलिए यह पहले से ही सॉर्ट किए गए स्थानों में है। अगला, हम 33 की तुलना 27 से करते हैं।
हम पाते हैं कि 27 33 से छोटा है और इन दो मूल्यों की अदला-बदली होनी चाहिए।
नए सरणी को इस तरह दिखना चाहिए -
अगला हम 33 और 35 की तुलना करते हैं। हम पाते हैं कि दोनों पहले से ही सॉर्ट किए गए पदों पर हैं।
फिर हम अगले दो मूल्यों, 35 और 10 पर जाते हैं।
हम जानते हैं कि 10 छोटा 35 है। इसलिए उन्हें छांटा नहीं गया है।
हम इन मूल्यों की अदला-बदली करते हैं। हम पाते हैं कि हम सरणी के अंत तक पहुँच चुके हैं। एक पुनरावृत्ति के बाद, सरणी इस तरह दिखना चाहिए -
सटीक होने के लिए, हम अब दिखा रहे हैं कि प्रत्येक पुनरावृत्ति के बाद सरणी कैसे दिखनी चाहिए। दूसरी पुनरावृत्ति के बाद, यह इस तरह दिखना चाहिए -
ध्यान दें कि प्रत्येक पुनरावृत्ति के बाद, अंत में कम से कम एक मान चलता है।
और जब कोई स्वैप की आवश्यकता नहीं होती है, तो बुलबुला प्रकार सीखता है कि एक सरणी पूरी तरह से सॉर्ट की गई है।
अब हमें बबल सॉर्ट के कुछ व्यावहारिक पहलुओं पर गौर करना चाहिए।
कलन विधि
हमारा मानना है list की एक सरणी है nतत्वों। हम आगे मान लेते हैंswap फ़ंक्शन दिए गए सरणी तत्वों के मूल्यों को स्वैप करता है।
begin BubbleSort(list)
for all elements of list
if list[i] > list[i+1]
swap(list[i], list[i+1])
end if
end for
return list
end BubbleSort
स्यूडोकोड
हम एल्गोरिथ्म में निरीक्षण करते हैं कि बबल सॉर्ट एरे तत्व के प्रत्येक जोड़े की तुलना करता है जब तक कि संपूर्ण एरे पूरी तरह से आरोही क्रम में सॉर्ट न हो जाए। इसके कारण कुछ जटिलताएँ हो सकती हैं, जैसे कि यदि सभी तत्वों के पहले से आरोही होने पर सरणी को और अधिक स्वैपिंग की आवश्यकता न हो।
समस्या को कम करने के लिए, हम एक ध्वज चर का उपयोग करते हैं swappedजो हमें यह देखने में मदद करेगा कि कोई स्वैप हुआ है या नहीं। यदि कोई स्वैप नहीं हुआ है, अर्थात सरणी को सॉर्ट करने के लिए अधिक प्रसंस्करण की आवश्यकता नहीं है, तो यह लूप से बाहर आ जाएगा।
बबलोर्ट एल्गोरिथ्म के छद्मकोड को इस प्रकार लिखा जा सकता है -
procedure bubbleSort( list : array of items )
loop = list.count;
for i = 0 to loop-1 do:
swapped = false
for j = 0 to loop-1 do:
/* compare the adjacent elements */
if list[j] > list[j+1] then
/* swap them */
swap( list[j], list[j+1] )
swapped = true
end if
end for
/*if no number was swapped that means
array is sorted now, break the loop.*/
if(not swapped) then
break
end if
end for
end procedure return list
कार्यान्वयन
एक और मुद्दा जिसे हमने अपने मूल एल्गोरिथ्म और इसके सुधारित छद्मकोश में नहीं संबोधित किया है, वह यह है कि प्रत्येक पुनरावृत्ति के बाद उच्चतम मान सरणी के अंत में बस जाते हैं। इसलिए, अगले पुनरावृत्ति में पहले से ही हल किए गए तत्व शामिल नहीं हैं। इस प्रयोजन के लिए, हमारे कार्यान्वयन में, हम पहले से ही हल किए गए मूल्यों से बचने के लिए आंतरिक लूप को प्रतिबंधित करते हैं।
सी प्रोग्रामिंग भाषा में बबल सॉर्ट कार्यान्वयन के बारे में जानने के लिए, कृपया यहां क्लिक करें ।