পোস্টটি পড়া হয়েছে 771 বার
Data Structure in Bengali

Deque বা Double-ended Queue

আগের পর্ব থেকে তোমরা জেনে গেছ Queue এর ব্যাসিক ধারণা। FIFO – First in First Out এই মূলনীতির উপর ভিত্তি করে কিউ ডেটা স্ট্রাকচার কাজ করে। তোমরা জানো যে একটা কিউতে নতুন কোন ডেটা ইনসার্ট করতে হলে কিউয়ের শেষে ইনসার্ট করতে হয়। আর কোন ডেটা বের করে নিতে হলে বা প্রসেস করতে হলে কিউয়ের শুরু থেকে বের করতে হয়।

Double-end Queue এর ক্ষেত্রে উপরের কাজগুলো করা যায়, সাথে আরো বাড়তি কিছু সুবিধা পাওয়া যায়। নাম দেখেই বুঝা যাচ্ছে এই কিউয়ের বৈশিষ্ট্য। Deque ব্যবহার করে তুমি কিউয়ের শুরু ও শেষ দুই দিকেই ডেটা ইনসার্ট করতে পারবা এবং দুই দিক দিয়েই ডেটা বের করতে পারবা। C++ এর STL ব্যবহার করে খুব সহজে deque ইমপ্লিমেন্ট করা যায়। চাইলে একটু খাটাখাটনি করে সাধারণ অ্যারে দিয়েও এটা ইমপ্লিমেন্ট করতে পারো।

Deque এর কয়েকটা সাধারণ ফাংশনালিটি দেখব এই পোস্টেঃ




  1. push_front() – কিউয়ের শুরুতে ডেটা ইনসার্ট করতে
  2. push_back() – কিয়ের শেষে ডেটা ইনসার্ট করতে
  3. pop_front() – কিউয়ের সামনে থেকে ডেটা pop করতে
  4. pop_back() – কিউয়ের শেষ থেকে ডেটা pop করতে
  5. front() – কিউয়ের সামনের ডেটা অ্যাক্সেস করতে
  6. back() – কিউয়ের শেষের ডেটা অ্যাক্সেস করতে
  7. clear() – কিউয়ের সকল ডেটা মুছে ফেলতে

একটা প্রোগ্রাম লিখব যাতে উপরের ক্রম অনুসারে ডিকিউ দিয়ে এই অপারেশনগুলো সম্পন্ন করা যায়। অর্থাৎ, 1 ইনপুট দিলে push_front() কাজ করবে। 4 ইনপুট দিলে pop_back() করবে। অনুরূপ ভাবে 7 ইনপুট দিলে সকল ডেটা মুছে ফেলা হবে।

কাজের সুবিধার্তে আরো দুইটা নতুন অপশন যোগ করি। 8 ইনপুট দিলে পুরো কিউটার আউটপুট দেখাবে। 9 ইনপুট দিলে প্রোগ্রাম exit করবে।

কিউয়ের আগের পর্ব পড়ে বুঝে থাকলে এই পর্ব বুঝতে কোনই সমস্যা হবার কথা নয়। তাই প্রতিটা মেথডের বিস্তারিত আলোচনা আর করলাম না। আশা করি ডিকিউ (আসলে উচ্চারণটা হবে ডেক্‌) বুঝা হয়ে গেছে। কোথাও কনফিউশন থাকলে কমেন্ট করতে ভুলো না। ও হ্যাঁ! আরেকটা কথা… deque-কে অনেক সময় head-tail linked list-ও বলা হয়ে থাকে।

ডিকিউ বুঝে গিয়ে থাকলে সলভ করতে পারবে LightOJ 1212 – Double Ended Queue এই প্রবলেমটি।

3 thoughts on “Deque বা Double-ended Queue

  1. My comment is not spam! Why it shows time and again that my comment is spam!
    I can’t make any comment now. Let’s try this time.

  2. I can’t make any comment in Bangla due to spam report! Whatever I am trying to comment, even just a simple line in Bangla, it reports as spam!! BIG PROBLEM.

Leave a Reply

Your email address will not be published. Required fields are marked *