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

स्टैक एक सार डेटा प्रकार (ADT) है, जो आमतौर पर अधिकांश प्रोग्रामिंग भाषाओं में उपयोग किया जाता है। इसे स्टैक नाम दिया गया है क्योंकि यह एक वास्तविक दुनिया स्टैक की तरह व्यवहार करता है, उदाहरण के लिए - कार्ड का एक डेक या प्लेटों का ढेर, आदि।

एक वास्तविक दुनिया स्टैक केवल एक छोर पर संचालन की अनुमति देता है। उदाहरण के लिए, हम केवल स्टैक के ऊपर से कार्ड या प्लेट को रख सकते हैं या हटा सकते हैं। इसी तरह, स्टैक एडीटी केवल एक छोर पर सभी डेटा संचालन की अनुमति देता है। किसी भी समय, हम केवल एक स्टैक के शीर्ष तत्व तक पहुंच सकते हैं।

यह सुविधा इसे LIFO डेटा संरचना बनाती है। LIFO का उद्देश्य लास्ट-इन-प्रथम-आउट है। यहां, जो तत्व अंतिम (सम्मिलित या जोड़ा गया) है, उसे पहले एक्सेस किया जाता है। स्टैक शब्दावली में, सम्मिलन ऑपरेशन कहा जाता हैPUSH ऑपरेशन और रिमूवल ऑपरेशन कहलाता है POP ऑपरेशन।

ढेर का प्रतिनिधित्व

निम्नलिखित चित्र में एक स्टैक और उसके संचालन को दर्शाया गया है -

स्टैक को एरे, स्ट्रक्चर, पॉइंटर और लिंक्ड लिस्ट के माध्यम से लागू किया जा सकता है। स्टैक या तो एक निश्चित आकार का हो सकता है या इसमें गतिशील आकार बदलने की भावना हो सकती है। यहां, हम सरणियों का उपयोग करके स्टैक को लागू करने जा रहे हैं, जो इसे एक निश्चित आकार स्टैक कार्यान्वयन बनाता है।

मूलभूत क्रियाएं

स्टैक संचालन में स्टैक को इनिशियलाइज़ करना, इसका उपयोग करना और फिर इसे डी-इनिशियलाइज़ करना शामिल हो सकता है। इन बुनियादी सामानों के अलावा, एक स्टैक का उपयोग निम्नलिखित दो प्राथमिक कार्यों के लिए किया जाता है -

  • push() - स्टैक पर एक तत्व को पुश करना (स्टोर करना)।

  • pop() - स्टैक से एक तत्व को निकालना (एक्सेस करना)।

जब डेटा को स्टैक पर PUSHed किया जाता है।

स्टैक का कुशलतापूर्वक उपयोग करने के लिए, हमें स्टैक की स्थिति की भी जांच करने की आवश्यकता है। एक ही उद्देश्य के लिए, निम्नलिखित कार्यक्षमता को ढेर में जोड़ा जाता है -

  • peek() - स्टैक का शीर्ष डेटा तत्व प्राप्त करें, इसे हटाए बिना।

  • isFull() - जांच करें कि क्या स्टैक भरा हुआ है।

  • isEmpty() - जांचें कि क्या स्टैक खाली है।

हर समय, हम स्टैक पर अंतिम PUSHed डेटा के लिए एक संकेतक बनाए रखते हैं। जैसा कि यह सूचक हमेशा स्टैक के शीर्ष का प्रतिनिधित्व करता है, इसलिए नाम दिया गया हैtoptop पॉइंटर वास्तव में इसे हटाने के बिना स्टैक का शीर्ष मूल्य प्रदान करता है।

स्टैक फ़ंक्शंस का समर्थन करने के लिए पहले हमें प्रक्रियाओं के बारे में सीखना चाहिए -

झांकना ()

झाँकी का एल्गोरिथ्म () फ़ंक्शन -

begin procedure peek
   return stack[top]
end procedure

सी प्रोग्रामिंग भाषा में झांकना () फ़ंक्शन का कार्यान्वयन -

Example

int peek() {
   return stack[top];
}

पूर्ण है()

आइफुल का एल्गोरिथ्म () फ़ंक्शन -

begin procedure isfull

   if top equals to MAXSIZE
      return true
   else
      return false
   endif
   
end procedure

C प्रोग्रामिंग भाषा में isfull () फ़ंक्शन का कार्यान्वयन -

Example

bool isfull() {
   if(top == MAXSIZE)
      return true;
   else
      return false;
}

खाली है()

समरूपता का समरूपता () फ़ंक्शन -

begin procedure isempty

   if top less than 1
      return true
   else
      return false
   endif
   
end procedure

C प्रोग्रामिंग भाषा में isempty () फ़ंक्शन का कार्यान्वयन थोड़ा अलग है। हम शीर्ष -1 पर इनिशियलाइज़ करते हैं, क्योंकि एरे में इंडेक्स 0. से शुरू होता है, इसलिए हम जाँचते हैं कि स्टैक शून्य है या नहीं, यह निर्धारित करने के लिए कि टॉप शून्य से नीचे है या नहीं। यहाँ कोड है -

Example

bool isempty() {
   if(top == -1)
      return true;
   else
      return false;
}

पुश ऑपरेशन

स्टैक पर एक नया डेटा तत्व डालने की प्रक्रिया को पुश ऑपरेशन के रूप में जाना जाता है। पुश ऑपरेशन में चरणों की एक श्रृंखला शामिल है -

  • Step 1 - अगर स्टैक भरा हुआ है तो चेक करता है।

  • Step 2 - यदि स्टैक भरा हुआ है, तो एक त्रुटि और निकास पैदा करता है।

  • Step 3 - यदि स्टैक पूर्ण नहीं है, तो वेतन वृद्धि top अगले खाली स्थान को इंगित करने के लिए।

  • Step 4 - डेटा तत्व को स्टैक स्थान पर जोड़ता है, जहां शीर्ष इंगित कर रहा है।

  • Step 5 - सफलता लौटाता है।

यदि स्टैक को लागू करने के लिए लिंक की गई सूची का उपयोग किया जाता है, तो चरण 3 में, हमें गतिशील रूप से स्थान आवंटित करने की आवश्यकता है।

PUSH ऑपरेशन के लिए एल्गोरिदम

पुश ऑपरेशन के लिए एक सरल एल्गोरिथ्म निम्नानुसार व्युत्पन्न किया जा सकता है -

begin procedure push: stack, data

   if stack is full
      return null
   endif
   
   top ← top + 1
   stack[top] ← data

end procedure

सी में इस एल्गोरिथ्म का कार्यान्वयन बहुत आसान है। निम्नलिखित कोड देखें -

Example

void push(int data) {
   if(!isFull()) {
      top = top + 1;   
      stack[top] = data;
   } else {
      printf("Could not insert data, Stack is full.\n");
   }
}

पॉप ऑपरेशन

स्टैक से हटाते समय सामग्री तक पहुंचना, पॉप ऑपरेशन के रूप में जाना जाता है। पॉप () ऑपरेशन के एक सरणी कार्यान्वयन में, डेटा तत्व को वास्तव में नहीं हटाया जाता है, इसके बजायtopअगले मान को इंगित करने के लिए स्टैक में एक निम्न स्थिति में कमी की गई है। लेकिन लिंक्ड-लिस्ट कार्यान्वयन में, पॉप () वास्तव में डेटा तत्व को हटा देता है और मेमोरी स्पेस को हटा देता है।

पॉप ऑपरेशन में निम्नलिखित चरण शामिल हो सकते हैं -

  • Step 1 - जाँच करता है कि स्टैक खाली है या नहीं।

  • Step 2 - यदि स्टैक खाली है, तो एक त्रुटि और निकास पैदा करता है।

  • Step 3 - यदि स्टैक खाली नहीं है, तो डेटा तत्व को एक्सेस करता है top इशारा कर रहा है।

  • Step 4 - शीर्ष का मान 1 घटाता है।

  • Step 5 - सफलता लौटाता है।

पॉप ऑपरेशन के लिए एल्गोरिदम

पॉप ऑपरेशन के लिए एक सरल एल्गोरिथ्म निम्नानुसार व्युत्पन्न किया जा सकता है -

begin procedure pop: stack

   if stack is empty
      return null
   endif
   
   data ← stack[top]
   top ← top - 1
   return data

end procedure

सी में इस एल्गोरिथ्म का कार्यान्वयन निम्नानुसार है -

Example

int pop(int data) {

   if(!isempty()) {
      data = stack[top];
      top = top - 1;   
      return data;
   } else {
      printf("Could not retrieve data, Stack is empty.\n");
   }
}

सी प्रोग्रामिंग भाषा में एक पूर्ण स्टैक प्रोग्राम के लिए, कृपया यहां क्लिक करें ।