Queue कई एल्गोरिथ्म में इस्तेमाल होने वाले मुख्य डेटा स्ट्रक्चर में से एक है। यह असल ज़िंदगी की कतार जैसी ही काम करती है। Queue में सबसे पहले जो तत्व (element) डाला जाता है, वही सबसे पहले “सर्व” होता है और Queue से हट जाता है।
एक काल्पनिक स्थिति की कल्पना कीजिए, जिसमें कॉफी लेने के लिए बहुत सारी चींटियाँ एक पंक्ति में (queue) खड़ी हैं। कतार में सबसे आगे खड़ी चींटी को पहले कॉफी मिलेगी और फिर वह कतार से बाहर चली जाएगी, उसके बाद अगली चींटी को कॉफी मिलेगी और वह भी कतार से बाहर चली जाएगी। यह सिलसिला तब तक चलता रहेगा जब तक कतार पूरी तरह से खाली नहीं हो जाती, यानी कोई चींटी कॉफी के इंतज़ार में न रह जाए।
अधिकांश प्रोग्रामिंग भाषाओं में Queue को डिक्लेयर और इस्तेमाल करना बहुत ही आसान बना दिया गया है, क्योंकि ज़्यादातर जनरल-पर्पस भाषाओं (जैसे Python, C++, Java इत्यादि) में Queue डेटा स्ट्रक्चर पहले से ही उपलब्ध है। फिर भी, हम चाहें तो लिंक्ड लिस्ट का इस्तेमाल करके खुद का Queue भी बना सकते हैं। क्या आप सोच सकते हैं कि यह कैसे किया जा सकता है 🤔?
from queue import Queue
q = Queue() # Create a new queue
q.put(1) # Add 1 to the front of the queue
q.put(2) # Add 2 next
q.put(3) # Add 3 after 2
# Remove elements from the queue using get()
print(q.get()) # prints 1
print(q.get()) # prints 2
print(q.get()) # prints 3
चुनौती: Queue सिमुलेशन
आप एक ऐसा सिस्टम बना रहे हैं जो स्टोर में आने वाले ग्राहकों का हिसाब रख सके। इस सिस्टम को दो काम करने चाहिए: पहला, किसी ग्राहक को प्रतीक्षा पंक्ति में जोड़ना; और दूसरा, जब ग्राहक का काम पूरा हो जाए, तो प्रतीक्षा पंक्ति में सबसे आगे वाले ग्राहक को हटाना। हर बार जब आप किसी ग्राहक को हटाएँ, आपको उसका नाम प्रिंट करना होगा।
इनपुट
इनपुट की पहली पंक्ति में एक पूर्णांक n (1 ≤ n ≤ 100 000) होता है।
अगली n पंक्तियों में दो तरह के ऑपरेशन हो सकते हैं — या तो add या pop:
add ऑपरेशन के बाद एक नाम आता है, जिसके ज़रिये आपको ग्राहक को प्रतीक्षा पंक्ति में जोड़ना चाहिए।
pop ऑपरेशन में सिर्फ ऑपरेशन का नाम होता है, और कुछ नहीं।
यह गारंटी है कि pop ऑपरेशन से पहले हमेशा किसी न किसी ग्राहक का इंतज़ार में रहना तय है, इसलिए ये ऑपरेशन मान्य (valid) होंगे।
नामों की लंबाई 20 प्रतीकों से अधिक नहीं होगी।
आउटपुट
हर pop ऑपरेशन के लिए, प्रोग्राम को प्रतीक्षा पंक्ति के सबसे आगे वाले ग्राहक का नाम प्रिंट करना चाहिए।
उदाहरण
इनपुट
आउटपुट
9 add Steven add Sam pop add Sergio add Don pop add John pop pop