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

कतार एक सार डेटा संरचना है, जो कुछ हद तक स्टैक्स के समान है। स्टैक के विपरीत, इसके दोनों सिरों पर एक कतार खुली होती है। एक सिरा हमेशा डेटा (enqueue) डालने के लिए और दूसरा डेटा (dequeue) को हटाने के लिए उपयोग किया जाता है। कतार फर्स्ट-इन-फर्स्ट-आउट कार्यप्रणाली का अनुसरण करती है, अर्थात, पहले संग्रहीत डेटा आइटम को पहले एक्सेस किया जाएगा।

कतार की वास्तविक दुनिया का उदाहरण सिंगल-लेन वन-वे रोड हो सकता है, जहां वाहन पहले प्रवेश करता है, पहले बाहर निकलता है। अधिक वास्तविक दुनिया के उदाहरणों को टिकट खिड़कियों और बस-स्टॉप पर कतारों के रूप में देखा जा सकता है।

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

जैसा कि अब हम समझते हैं कि कतार में, हम अलग-अलग कारणों से दोनों छोरों तक पहुंचते हैं। नीचे दिए गए निम्नलिखित चित्र डेटा संरचना के रूप में कतार प्रतिनिधित्व को समझाने की कोशिश करते हैं -

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

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

कतार के संचालन में कतार को प्रारंभिक या परिभाषित करना, उसका उपयोग करना, और फिर इसे स्मृति से पूरी तरह से मिटाना शामिल हो सकता है। यहां हम कतारों से जुड़े बुनियादी कार्यों को समझने की कोशिश करेंगे -

  • enqueue() - कतार में एक आइटम जोड़ें (स्टोर करें)।

  • dequeue() - कतार से किसी आइटम को निकालें (एक्सेस करें)।

उपर्युक्त कतार संचालन को कुशल बनाने के लिए कुछ और कार्यों की आवश्यकता होती है। ये हैं -

  • peek() - कतार के सामने तत्व को बिना हटाए रखा जाता है।

  • isfull() - कतार भर गई तो चेक।

  • isempty() - कतार खाली होने पर चेक करता है।

कतार में, हम हमेशा इंगित किए गए डेटा (या एक्सेस) को धोखा देते हैं front पॉइंटर और जबकि (या भंडारण) डेटा कतार में हम मदद लेते हैं rear सूचक।

आइए पहले एक कतार के सहायक कार्यों के बारे में जानें -

झांकना ()

यह फ़ंक्शन डेटा को देखने में मदद करता है frontकतार का। झाँकी का एल्गोरिथ्म () फ़ंक्शन निम्नानुसार है -

Algorithm

begin procedure peek
   return queue[front]
end procedure

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

Example

int peek() {
   return queue[front];
}

पूर्ण है()

जैसा कि हम कतार को लागू करने के लिए एकल आयाम सरणी का उपयोग कर रहे हैं, हम सिर्फ यह निर्धारित करने के लिए अधिकतम सूचक की जांच करते हैं कि कतार पूर्ण है या नहीं। मामले में हम कतार को एक गोलाकार लिंक-सूची में बनाए रखते हैं, एल्गोरिथ्म अलग होगा। आइफुल का एल्गोरिथ्म () फ़ंक्शन -

Algorithm

begin procedure isfull

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

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

Example

bool isfull() {
   if(rear == MAXSIZE - 1)
      return true;
   else
      return false;
}

खाली है()

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

Algorithm

begin procedure isempty

   if front is less than MIN  OR front is greater than rear
      return true
   else
      return false
   endif
   
end procedure

यदि का मान front यह MIN या 0 से कम है, यह बताता है कि कतार अभी आरंभिक नहीं है, इसलिए खाली है।

यहाँ C प्रोग्रामिंग कोड है -

Example

bool isempty() {
   if(front < 0 || front > rear) 
      return true;
   else
      return false;
}

एनक्यू ऑपरेशन

कतारें दो डेटा पॉइंट बनाए रखती हैं, front तथा rear। इसलिए, स्टैक की तुलना में इसके संचालन को तुलनात्मक रूप से लागू करना मुश्किल है।

निम्नलिखित चरणों को एक कतार में डेटा (सम्मिलित) करने के लिए लिया जाना चाहिए -

  • Step 1 - जाँच करें कि कतार भरी हुई है या नहीं।

  • Step 2 - यदि कतार भरी है, तो अतिप्रवाह त्रुटि और बाहर निकलें।

  • Step 3 - कतार पूरी न होने पर वेतन वृद्धि rear पॉइंटर अगली खाली जगह को इंगित करने के लिए।

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

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

कभी-कभी, हम यह देखने के लिए भी जाँच करते हैं कि कोई विषम परिस्थितियों को संभालने के लिए कोई कतार आरम्भिक है या नहीं।

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

procedure enqueue(data)      
   
   if queue is full
      return overflow
   endif
   
   rear ← rear + 1
   queue[rear] ← data
   return true
   
end procedure

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

Example

int enqueue(int data)      
   if(isfull())
      return 0;
   
   rear = rear + 1;
   queue[rear] = data;
   
   return 1;
end procedure

Dequeue ऑपरेशन

कतार से डेटा एक्सेस करना दो कार्यों की एक प्रक्रिया है - डेटा को एक्सेस करना जहाँ frontपहुँच के बाद डेटा को इंगित और निकाल रहा है। प्रदर्शन करने के लिए निम्नलिखित कदम उठाए जाते हैंdequeue ऑपरेशन -

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

  • Step 2 - यदि कतार खाली है, तो अंडरफ़्लो त्रुटि और बाहर निकलें।

  • Step 3 - यदि कतार खाली नहीं है, तो डेटा तक पहुंचें जहां front इशारा कर रहा है।

  • Step 4 - वृद्धि front पॉइंटर अगले उपलब्ध डेटा तत्व को इंगित करने के लिए।

  • Step 5 - वापसी सफलता।

Dequeue ऑपरेशन के लिए एल्गोरिथ्म

procedure dequeue
   
   if queue is empty
      return underflow
   end if

   data = queue[front]
   front ← front + 1
   return true

end procedure

सी प्रोग्रामिंग भाषा में छल का कार्यान्वयन () -

Example

int dequeue() {
   if(isempty())
      return 0;

   int data = queue[front];
   front = front + 1;

   return data;
}

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