डेटा संरचना - छँटाई तकनीक
सॉर्टिंग एक विशेष प्रारूप में डेटा की व्यवस्था करने को संदर्भित करता है। सॉर्टिंग एल्गोरिथ्म एक विशेष क्रम में डेटा को व्यवस्थित करने का तरीका निर्दिष्ट करता है। अधिकांश सामान्य आदेश संख्यात्मक या शाब्दिक क्रम में होते हैं।
छंटनी का महत्व इस तथ्य में निहित है कि डेटा खोज को बहुत उच्च स्तर पर अनुकूलित किया जा सकता है, यदि डेटा को सॉर्ट किए गए तरीके से संग्रहीत किया जाता है। अधिक पठनीय प्रारूपों में डेटा का प्रतिनिधित्व करने के लिए सॉर्टिंग का भी उपयोग किया जाता है। वास्तविक जीवन के परिदृश्यों में छँटाई के कुछ उदाहरण निम्नलिखित हैं -
Telephone Directory - टेलीफोन निर्देशिका अपने नाम से छांटे गए लोगों के टेलीफोन नंबर संग्रहीत करती है, ताकि नामों को आसानी से खोजा जा सके।
Dictionary - शब्दकोश शब्दों को वर्णमाला क्रम में संग्रहीत करता है ताकि किसी भी शब्द की खोज आसान हो जाए।
इन-प्लेस सॉर्टिंग और नॉट-इन-प्लेस सॉर्टिंग
छँटाई एल्गोरिदम कुछ डेटा तत्वों की तुलना और अस्थायी भंडारण के लिए कुछ अतिरिक्त स्थान की आवश्यकता हो सकती है। इन एल्गोरिदम को किसी भी अतिरिक्त स्थान की आवश्यकता नहीं होती है और छँटाई को जगह में या उदाहरण के लिए, सरणी के भीतर ही होने के लिए कहा जाता है। यह कहा जाता हैin-place sorting। बबल सॉर्ट इन-प्लेस सॉर्टिंग का एक उदाहरण है।
हालाँकि, कुछ सॉर्टिंग एल्गोरिदम में, प्रोग्राम को स्पेस की आवश्यकता होती है जो सॉर्ट किए जा रहे तत्वों से अधिक या बराबर होता है। छँटाई जो समान या अधिक स्थान का उपयोग करता है उसे कहा जाता हैnot-in-place sorting। मर्ज-सॉर्ट जगह-जगह छँटाई का एक उदाहरण है।
स्थिर और स्थिर नहीं छँटाई
यदि एक छँटाई एल्गोरिथ्म, सामग्री को छाँटने के बाद, समान सामग्री के अनुक्रम को नहीं बदलता है जिसमें वे दिखाई देते हैं, इसे कहा जाता है stable sorting।
यदि एक छँटाई एल्गोरिथ्म, सामग्री को क्रमबद्ध करने के बाद, उसी सामग्री के अनुक्रम को बदलता है जिसमें वे दिखाई देते हैं, इसे कहा जाता है unstable sorting।
एक एल्गोरिथ्म की स्थिरता मायने रखती है जब हम मूल तत्वों के अनुक्रम को बनाए रखना चाहते हैं, जैसे कि उदाहरण के लिए एक टपल में।
अनुकूली और गैर-अनुकूली छँटाई एल्गोरिथ्म
एक छँटाई एल्गोरिथ्म को अनुकूली कहा जाता है, अगर यह सूची में पहले से ही 'क्रमबद्ध' तत्वों का लाभ उठाता है जिसे क्रमबद्ध किया जाना है। यदि स्रोत सूची में कुछ तत्व पहले से ही छंटे हुए हैं, तो यह छांटते समय, अनुकूली एल्गोरिदम इसे ध्यान में रखेंगे और उन्हें फिर से क्रम में नहीं लाने का प्रयास करेंगे।
एक गैर-अनुकूली एल्गोरिथ्म वह है जो पहले से ही हल किए गए तत्वों को ध्यान में नहीं रखता है। वे हर एक तत्व को उनकी छँटाई की पुष्टि के लिए फिर से आदेश देने के लिए मजबूर करने की कोशिश करते हैं।
महत्वपूर्ण शर्तें
कुछ शर्तों को आमतौर पर छँटाई तकनीकों पर चर्चा करते समय गढ़ा जाता है, यहाँ उनका संक्षिप्त परिचय दिया गया है -
बढ़ता हुआ क्रम
मूल्यों का एक क्रम में कहा जाता है increasing order, यदि क्रमिक तत्व पिछले एक से अधिक है। उदाहरण के लिए, 1, 3, 4, 6, 8, 9 बढ़ते क्रम में हैं, क्योंकि प्रत्येक अगला तत्व पिछले तत्व से अधिक है।
घटता क्रम
मूल्यों का एक क्रम में कहा जाता है decreasing order, यदि क्रमिक तत्व वर्तमान से कम है। उदाहरण के लिए, 9, 8, 6, 4, 3, 1 घटते क्रम में हैं, क्योंकि प्रत्येक अगला तत्व पिछले तत्व से कम है।
गैर-बढ़ते आदेश
मूल्यों का एक क्रम में कहा जाता है non-increasing order, यदि क्रमिक तत्व अनुक्रम में अपने पिछले तत्व से कम या बराबर है। यह क्रम तब होता है जब अनुक्रम में डुप्लिकेट मान होते हैं। उदाहरण के लिए, 9, 8, 6, 3, 3, 1 गैर-बढ़ते क्रम में हैं, क्योंकि हर अगला तत्व (3 के मामले में) से कम या बराबर है, लेकिन किसी भी पिछले तत्व से अधिक नहीं है।
गैर-घटता क्रम
मूल्यों का एक क्रम में कहा जाता है non-decreasing order, यदि क्रमिक तत्व अनुक्रम में अपने पिछले तत्व से अधिक या बराबर है। यह क्रम तब होता है जब अनुक्रम में डुप्लिकेट मान होते हैं। उदाहरण के लिए, 1, 3, 3, 6, 8, 9 गैर-घटते क्रम में हैं, क्योंकि प्रत्येक अगला तत्व (3 के मामले में) से अधिक या बराबर है, लेकिन पिछले एक से कम नहीं है।