डेटा संरचनाएं - एल्गोरिदम मूल बातें
एल्गोरिथम एक चरण-दर-चरण प्रक्रिया है, जो वांछित आउटपुट प्राप्त करने के लिए एक निश्चित क्रम में निष्पादित होने वाले निर्देशों के एक सेट को परिभाषित करता है। एल्गोरिदम को आमतौर पर अंतर्निहित भाषाओं से स्वतंत्र बनाया जाता है, अर्थात एक एल्गोरिथ्म को एक से अधिक प्रोग्रामिंग भाषा में लागू किया जा सकता है।
डेटा संरचना के दृष्टिकोण से, एल्गोरिदम की कुछ महत्वपूर्ण श्रेणियां निम्नलिखित हैं -
Search - डेटा संरचना में किसी आइटम को खोजने के लिए एल्गोरिदम।
Sort - एक निश्चित क्रम में आइटम सॉर्ट करने के लिए एल्गोरिदम।
Insert - डेटा संरचना में आइटम सम्मिलित करने के लिए एल्गोरिदम।
Update - डेटा संरचना में किसी मौजूदा आइटम को अपडेट करने के लिए एल्गोरिदम।
Delete - डेटा संरचना से किसी मौजूदा आइटम को हटाने के लिए एल्गोरिदम।
एक एल्गोरिथ्म के लक्षण
सभी प्रक्रियाओं को एक एल्गोरिथ्म नहीं कहा जा सकता है। एक एल्गोरिथ्म में निम्नलिखित विशेषताएं होनी चाहिए -
Unambiguous- एल्गोरिथ्म स्पष्ट और स्पष्ट होना चाहिए। इसके प्रत्येक चरण (या चरण), और उनके इनपुट / आउटपुट स्पष्ट होने चाहिए और केवल एक अर्थ के लिए होने चाहिए।
Input - एक एल्गोरिथ्म में 0 या अधिक अच्छी तरह से परिभाषित इनपुट होना चाहिए।
Output - एक एल्गोरिथ्म में 1 या अधिक अच्छी तरह से परिभाषित आउटपुट होना चाहिए, और वांछित आउटपुट से मेल खाना चाहिए।
Finiteness - चरणों की एक सीमित संख्या के बाद एल्गोरिदम को समाप्त करना चाहिए।
Feasibility - उपलब्ध संसाधनों के साथ व्यवहार्य होना चाहिए।
Independent - एक एल्गोरिथ्म में चरण-दर-चरण निर्देश होना चाहिए, जो किसी भी प्रोग्रामिंग कोड से स्वतंत्र होना चाहिए।
एलगोरिदम कैसे लिखें?
एल्गोरिदम लिखने के लिए कोई अच्छी तरह से परिभाषित मानक नहीं हैं। बल्कि, यह समस्या और संसाधन निर्भर है। एल्गोरिदम कभी भी किसी विशेष प्रोग्रामिंग कोड का समर्थन करने के लिए नहीं लिखा जाता है।
जैसा कि हम जानते हैं कि सभी प्रोग्रामिंग भाषाओं में लूप (जैसे, के लिए, जबकि), प्रवाह-नियंत्रण (यदि-आदि), जैसे बुनियादी कोड निर्माण हैं, तो इन आम निर्माण का उपयोग एल्गोरिदम लिखने के लिए किया जा सकता है।
हम चरण-दर-चरण तरीके से एल्गोरिदम लिखते हैं, लेकिन यह हमेशा ऐसा नहीं होता है। एल्गोरिदम लेखन एक प्रक्रिया है और समस्या डोमेन के अच्छी तरह से परिभाषित होने के बाद निष्पादित की जाती है। यही है, हमें समस्या डोमेन पता होना चाहिए, जिसके लिए हम एक समाधान डिज़ाइन कर रहे हैं।
उदाहरण
आइए एक उदाहरण का उपयोग करके एल्गोरिथ्म-लेखन सीखने की कोशिश करें।
Problem - दो नंबर जोड़ने और परिणाम प्रदर्शित करने के लिए एक एल्गोरिथ्म डिज़ाइन करें।
Step 1 − START
Step 2 − declare three integers a, b & c
Step 3 − define values of a & b
Step 4 − add values of a & b
Step 5 − store output of step 4 to c
Step 6 − print c
Step 7 − STOP
एल्गोरिदम प्रोग्रामर को बताते हैं कि प्रोग्राम को कैसे कोड किया जाए। वैकल्पिक रूप से, एल्गोरिथ्म के रूप में लिखा जा सकता है -
Step 1 − START ADD
Step 2 − get values of a & b
Step 3 − c ← a + b
Step 4 − display c
Step 5 − STOP
एल्गोरिदम के डिजाइन और विश्लेषण में, आमतौर पर एक एल्गोरिथ्म का वर्णन करने के लिए दूसरी विधि का उपयोग किया जाता है। यह विश्लेषक के लिए सभी अवांछित परिभाषाओं की अनदेखी करने वाले एल्गोरिथम का विश्लेषण करना आसान बनाता है। वह देख सकता है कि किस ऑपरेशन का उपयोग किया जा रहा है और प्रक्रिया कैसे चल रही है।
लिख रहे हैं step numbers, वैकल्पिक है।
हम किसी दिए गए समस्या का समाधान पाने के लिए एक एल्गोरिथ्म डिज़ाइन करते हैं। एक समस्या को एक से अधिक तरीकों से हल किया जा सकता है।
इसलिए, किसी समस्या के लिए कई समाधान एल्गोरिदम निकाले जा सकते हैं। अगला कदम उन प्रस्तावित समाधान एल्गोरिदम का विश्लेषण करना और सर्वोत्तम उपयुक्त समाधान को लागू करना है।
एल्गोरिथम विश्लेषण
एक एल्गोरिथ्म की क्षमता का विश्लेषण दो अलग-अलग चरणों में किया जा सकता है, कार्यान्वयन से पहले और कार्यान्वयन के बाद। वे निम्नलिखित हैं -
A Priori Analysis- यह एक एल्गोरिथ्म का सैद्धांतिक विश्लेषण है। एक एल्गोरिथ्म की दक्षता यह मानकर मापा जाता है कि अन्य सभी कारक, उदाहरण के लिए, प्रोसेसर की गति स्थिर है, और कार्यान्वयन पर कोई प्रभाव नहीं है।
A Posterior Analysis- यह एक एल्गोरिथ्म का एक अनुभवजन्य विश्लेषण है। चयनित एल्गोरिथ्म को प्रोग्रामिंग भाषा का उपयोग करके कार्यान्वित किया जाता है। इसके बाद लक्ष्य कंप्यूटर मशीन पर क्रियान्वित किया जाता है। इस विश्लेषण में, रनिंग टाइम और स्पेस की आवश्यकता जैसे वास्तविक आंकड़े एकत्र किए जाते हैं।
हम एक प्राथमिक एल्गोरिथ्म विश्लेषण के बारे में सीखेंगे । एल्गोरिदम विश्लेषण शामिल विभिन्न कार्यों के निष्पादन या चलने के समय से संबंधित है। किसी ऑपरेशन के चल रहे समय को प्रति ऑपरेशन निष्पादित कंप्यूटर निर्देशों की संख्या के रूप में परिभाषित किया जा सकता है।
एल्गोरिथ्म जटिलता
मान लीजिए X एक एल्गोरिथ्म है और n इनपुट डेटा का आकार, एल्गोरिदम एक्स द्वारा उपयोग किए जाने वाले समय और स्थान दो मुख्य कारक हैं, जो एक्स की दक्षता तय करते हैं।
Time Factor - समय को छँटाई एल्गोरिथ्म में तुलना जैसे प्रमुख संचालन की संख्या की गणना करके मापा जाता है।
Space Factor - एल्गोरिथ्म द्वारा आवश्यक अधिकतम मेमोरी स्पेस की गणना करके अंतरिक्ष को मापा जाता है।
एक एल्गोरिथ्म की जटिलता f(n) एल्गोरिथ्म के संदर्भ में आवश्यक रनिंग टाइम और / या स्टोरेज स्पेस देता है n इनपुट डेटा के आकार के रूप में।
अंतरिक्ष जटिलता
एक एल्गोरिथ्म की अंतरिक्ष जटिलता एल्गोरिदम द्वारा अपने जीवन चक्र में आवश्यक मेमोरी स्पेस की मात्रा का प्रतिनिधित्व करती है। एक एल्गोरिथ्म के लिए आवश्यक स्थान निम्नलिखित दो घटकों के योग के बराबर है -
एक निश्चित भाग जो कुछ डेटा और चर को संग्रहीत करने के लिए आवश्यक स्थान है, जो समस्या के आकार से स्वतंत्र है। उदाहरण के लिए, सरल चर और स्थिरांक का उपयोग किया जाता है, कार्यक्रम का आकार, आदि।
एक चर हिस्सा चर के लिए आवश्यक स्थान है, जिसका आकार समस्या के आकार पर निर्भर करता है। उदाहरण के लिए, डायनामिक मेमोरी एलोकेशन, रिकर्सन स्टैक स्पेस आदि।
किसी भी एल्गोरिथ्म P का स्पेस जटिलता S (P) S (P) = C + SP (I) है, जहां C निश्चित भाग है और S (I) एल्गोरिथ्म का चर भाग है, जो कि उदाहरण विशेषता I पर निर्भर करता है। एक सरल उदाहरण है जो अवधारणा को समझाने की कोशिश करता है -
Algorithm: SUM(A, B)
Step 1 - START
Step 2 - C ← A + B + 10
Step 3 - Stop
यहाँ हमारे पास तीन चर A, B, और C और एक स्थिर है। इसलिए S (P) = 1 + 3. अब, स्पेस दिए गए वैरिएबल और स्थिर प्रकार के डेटा प्रकारों पर निर्भर करता है और इसे उसी के अनुसार गुणा किया जाएगा।
समय जटिलता
एक एल्गोरिथ्म की समय जटिलता एल्गोरिदम को पूरा करने के लिए चलाने के लिए आवश्यक समय की मात्रा का प्रतिनिधित्व करती है। समय की आवश्यकताओं को एक संख्यात्मक कार्य T (n) के रूप में परिभाषित किया जा सकता है, जहां T (n) को चरणों की संख्या के रूप में मापा जा सकता है, बशर्ते प्रत्येक चरण में निरंतर समय की खपत हो।
उदाहरण के लिए, दो n-बिट पूर्णांकों के अलावा लेता है nकदम। नतीजतन, कुल कम्प्यूटेशनल समय T (n) = c where n है, जहां c दो बिट्स के जोड़ के लिए लिया गया समय है। यहां, हम मानते हैं कि इनपुट आकार बढ़ने के साथ टी (एन) रैखिक रूप से बढ़ता है।