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

Deque বা Double-ended Queue

Post updated on 24th January, 2017 at 12:49 am

আগের পর্ব থেকে তোমরা জেনে গেছ 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 করবে।

#include<bits/stdc++.h>

using namespace std;

int main()
{
    int choise, data;
    deque<int> myDeque;
    deque<int>::iterator it;

    while(true)
    {
        cout<<"\n\nChoose anyone:\n";
        cout<<"1. push_front()\t2. push_back()\t3. pop_front()\t 4. pop_back()\n";
        cout<<"5. front()\t 6. back()\t 7. clear()\t 8. show all elements\t 9. exit\n\n";

        cin>>choise;
        if(choise==1)
        {
            cout<<"Enter an integer to push it front\n";
            cin>>data;
            myDeque.push_front(data);
        }
        else if(choise==2)
        {
            cout<<"Enter an integer to push it back\n";
            cin>>data;
            myDeque.push_back(data);
        }
        else if(choise==3)
        {
            if(!myDeque.empty())
                myDeque.pop_front();
            else
                cout<<"Deque is empty!\n";
        }
        else if(choise==4)
        {
            if(!myDeque.empty())
                myDeque.pop_back();
            else
                cout<<"Deque is empty!\n";
        }
        else if(choise==5)
        {
            cout<<"Top front element is: "<<myDeque.front();
        }
        else if(choise==6)
        {
            cout<<"Top back element is: "<<myDeque.back();
        }
        else if(choise==7)
        {
            myDeque.clear();
            cout<<"Deque is clear now!\n";
        }
        else if(choise==8)
        {
            if(!myDeque.empty())
            {
                cout<<endl<<"Full Deque is:\n";
                for(it=myDeque.begin(); it != myDeque.end(); it++)
                    cout<<*it<<endl;
                cout<<endl;
            }
            else
                cout<<"Deque is empty!\n";

        }
        else if(choise==9)
            break;
        else
            cout<<"Invalid input!\n";

    }


    return 0;
}

কিউয়ের আগের পর্ব পড়ে বুঝে থাকলে এই পর্ব বুঝতে কোনই সমস্যা হবার কথা নয়। তাই প্রতিটা মেথডের বিস্তারিত আলোচনা আর করলাম না। আশা করি ডিকিউ (আসলে উচ্চারণটা হবে ডেক্‌) বুঝা হয়ে গেছে। কোথাও কনফিউশন থাকলে কমেন্ট করতে ভুলো না। ও হ্যাঁ! আরেকটা কথা… 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 *