সরাসরি প্রধান সামগ্রীতে চলে যান

কিউ ডেটা স্ট্রাকচার এর সহজ পাঠ


Introduction

আজকের এই ব্লগে আমরা কম্পিউটারের অন্যতম গুরুত্বপূর্ণ একটি ডেটা স্ট্রাকচার 'Queue' (কিউ) সম্পর্কে একদম সহজ ভাষায় জানব। কিউ মানে হলো লাইন। যেমন আমরা বাসের টিকিট কাটার জন্য লাইনে দাঁড়াই, ঠিক তেমনি কম্পিউটারেও ডেটাগুলোকে সাজিয়ে রাখার একটা বিশেষ পদ্ধতি হলো এই কিউ। এই ভিডিওতে শ্রধা খাপরা (Shradha Khapra) ম্যাম খুব সুন্দরভাবে দেখিয়েছেন কিউ কীভাবে কাজ করে, কীভাবে একে কোড দিয়ে তৈরি করতে হয় এবং c++ এ শর্টকাট উপায়ে কীভাবে এটি ব্যবহার করা যায়।


১. কিউ (Queue) আসলে কী?

কিউ হলো একটি FIFO (First In First Out) ডেটা স্ট্রাকচার। এর মানে হলো, যে ডেটা সবার আগে লাইনে ঢুকবে, সেই সবার আগে বের হবে।

সহজ উদাহরণ: ধরো, একটি লাইনে ৫ জন মানুষ দাঁড়িয়েছে। যে সবার সামনে আছে, সেই আগে সেবা পাবে এবং লাইন থেকে বের হয়ে যাবে। নতুন কেউ আসলে তাকে লাইনের পেছনে দাঁড়াতে হবে।

ভিডিও রেফারেন্স: [00:32]

কঠিন শব্দের ব্যাখ্যা:

  • FIFO (First In First Out): সহজ কথায়, "আগে আসলে আগে পাবেন" নীতি।

  • Front (ফ্রন্ট): লাইনের একদম সামনের অংশ, যেখান থেকে ডেটা বের করা হয়।

  • Rear (রিয়ার): লাইনের একদম পেছনের অংশ, যেখানে নতুন ডেটা যোগ করা হয়।


২. কিউ এর প্রধান অপারেশনগুলো

একটি কিউতে মূলত ৩টি কাজ বেশি করা হয়:

  • Push (পাস) বা Enqueue: লাইনের পেছনে নতুন কিছু যোগ করা। [01:03]

  • Pop (পপ) বা Dequeue: লাইনের একদম সামনে থেকে কাউকে সরিয়ে ফেলা। [01:22]

  • Front: লাইনের একদম সামনে কে আছে তা দেখা (কিন্তু তাকে সরানো নয়)। [01:42]

আমার চিন্তা: কিউ অনেকটা পাইপের মতো। একদিক দিয়ে পানি ঢুকছে (Rear) আর অন্যদিক দিয়ে বের হচ্ছে (Front)। পাইপের মাঝখানে থাকা পানিকে আমরা আগে বের করতে পারি না।


৩. কোডিং এর মাধ্যমে কিউ তৈরি (Linked List ব্যবহার করে)

ভিডিওতে দেখানো হয়েছে কীভাবে লিংকড লিস্ট (Linked List) ব্যবহার করে স্ক্র্যাচ থেকে কিউ তৈরি করা যায়। এখানে আমরা Node ক্লাস ব্যবহার করি।

কোড স্নিপেট (C++):

C++

#include <iostream>
using namespace std;

// নোড তৈরি করা
class Node {
public:
    int data;
    Node* next;
    Node(int val) {
        data = val;
        next = NULL;
    }
};

// কিউ ক্লাস
class Queue {
    Node* head; // ফ্রন্ট
    Node* tail; // রিয়ার

public:
    Queue() {
        head = tail = NULL;
    }

    // নতুন ডেটা যোগ করা (Push)
    void push(int x) {
        Node* newNode = new Node(x);
        if (head == NULL) {
            head = tail = newNode;
            return;
        }
        tail->next = newNode;
        tail = newNode;
    }

    // সামনে থেকে সরানো (Pop)
    void pop() {
        if (head == NULL) return;
        Node* temp = head;
        head = head->next;
        delete temp;
    }

    // সামনের ডেটা দেখা
    int front() {
        if (head == NULL) return -1;
        return head->data;
    }

    bool empty() {
        return head == NULL;
    }
}; 

ব্যাখ্যা:

  • আমরা একটি Queue ক্লাস তৈরি করেছি যাতে head (সামনে) এবং tail (পেছনে) আছে।

  • push করার সময় আমরা লেজে (tail) নতুন নোড জুড়ে দিচ্ছি।

  • pop করার সময় মাথার (head) নোডটি সরিয়ে দিচ্ছি।


৪. STL এবং ডাবল এন্ডেড কিউ (Deque)

সবসময় নিজে হাতে কিউ বানাতে হয় না। C++ এ STL (Standard Template Library) আছে যা আমাদের সরাসরি কিউ ব্যবহার করতে দেয়।

এছাড়াও একটি মজার জিনিস হলো Deque (Double Ended Queue)। সাধারণ কিউতে শুধু একদিক দিয়ে ঢোকা আর অন্যদিক দিয়ে বের হওয়া যায়। কিন্তু Deque-এ আপনি সামনে বা পেছনে, যেকোনো দিক দিয়েই ডেটা ঢুকাতে বা বের করতে পারবেন। [15:25]

ভিডিও রেফারেন্স: [16:32]


৫. বিশ্লেষণ ও আমার মতামত

কন্টেন্ট ক্রিয়েটর যা বোঝাতে চেয়েছেন: শ্রধা ম্যাম বোঝাতে চেয়েছেন যে কিউ শুধু একটা তাত্ত্বিক বিষয় নয়, এটি ইন্টারভিউ এবং বাস্তব জীবনে (যেমন: প্রিন্টারে ডকুমেন্ট সিরিয়াল হওয়া, রাউটারে ডেটা প্যাকেট আসা) প্রচুর ব্যবহৃত হয়। কিউ এর সব অপারেশনের টাইম কমপ্লেক্সিটি O(1), অর্থাৎ এটি খুব দ্রুত কাজ করে।

বাস্তব প্রেক্ষাপট ও পরামর্শ:

  • বাস্তবতা: আপনি যখন গ্রাফ (Graph) অ্যালগরিদম যেমন BFS (Breadth First Search) শিখবেন, তখন কিউ ছাড়া এক কদমও চলতে পারবেন না। [00:26]

  • বিকল্প: আপনি যদি অ্যারে (Array) দিয়ে কিউ বানান, তবে মেমোরি নষ্ট হওয়ার ভয় থাকে। তাই লিঙ্কড লিস্ট বা সার্কুলার কিউ (Circular Queue) ব্যবহার করা ভালো।

  • পরামর্শ: শুরুতে কনসেপ্ট বোঝার জন্য নিজে কোড করে কিউ বানান, কিন্তু বড় প্রজেক্ট বা কম্পিটিটিভ প্রোগ্রামিংয়ে সবসময় STL ব্যবহার করবেন কারণ এটি অনেক বেশি অপ্টিমাইজড।

ভিডিও লিংক: New Chapter : Queue Data Structure

[

New Chapter : Queue Data Structure

Shradha Khapra · 160K views

](http://www.youtube.com/watch?v=Khf9v67Ya30)

মন্তব্যসমূহ

এই ব্লগটি থেকে জনপ্রিয় পোস্টগুলি

সিজ্জিন (Sijjin) vs ইল্লিয়িন (Illiyin) পার্থক্য Difference

Sijjin (سِجِّين) এবং Illiyin (عِلِّيِّين) —এ দুটি শব্দ কুরআনে এসেছে এবং দুটোই মানুষের আমলনামা সংরক্ষণ সম্পর্কিত স্থানকে নির্দেশ করে। ১. সিজ্জিন (Sijjin) সিজ্জিন হলো পাপীদের (কাফের, মুনাফিক ও দুরাচারীদের) আমলনামা সংরক্ষণের স্থান। এটি সাত তলদেশের নীচে এক কারাগার বা অন্ধকার জগতে অবস্থিত বলে উল্লেখ রয়েছে। সূরা আল-মুতাফফিফীন (৮৩:৭-৯) তে বলা হয়েছে: "كَلَّا إِنَّ كِتَابَ الْفُجَّارِ لَفِي سِجِّينٍ ۝ وَمَا أَدْرَاكَ مَا سِجِّينٌ ۝ كِتَابٌ مَرْقُومٌ" অর্থ: "না, পাপীদের আমলনামা সিজ্জিনে সংরক্ষিত। তুমি কি জানো, সিজ্জিন কী? এটি এক লিখিত দলিল।" সিজ্জিনকে একটি কারাগার, সংকীর্ণ স্থান, বা নিচের স্তরে অবস্থিত এক অন্ধকার দুনিয়া হিসেবে ব্যাখ্যা করা হয়। ২. ইল্লিয়িন (Illiyin) ইল্লিয়িন হলো সৎকর্মশীলদের (মুমিন ও নেককারদের) আমলনামা সংরক্ষণের স্থান । এটি সপ্তম আসমানের ওপরে সংরক্ষিত এক সম্মানিত স্থান। সূরা আল-মুতাফফিফীন (৮৩:১৮-২১) তে বলা হয়েছে: "كَلَّا إِنَّ كِتَابَ الْأَبْرَارِ لَفِي عِلِّيِّينَ ۝ وَمَا أَدْرَاكَ مَا عِلِّيُّونَ ۝ كِتَابٌ مَرْقُومٌ ۝ يَش...

রেডমি নোট ৯ এর বিস্তারিত | Redmi Note 9 in Bangla

৩০ এপ্রিল, ২০২০ এ শাওমির ঘোষনা আসে এই ফোনটি নিয়ে। কিন্তু ফোনটি মার্কেটে আসে মে মাসের শেষের দিকে৷ করোনার কারনে ফোনটি বাংলাদেশে আসতে আরো সময় নেয়। বর্তমানে বাংলাদেশে আন অফিশিয়াল ভাবে ফোনটি পাওয়া যাচ্ছে৷ বাংলাদেশে অফিশিয়াল ভাবে এখনো ফোনটি আসার তথ্য নেয়৷ চলুন ফোনটি নিয়ে বিস্তারিত আলোচনা করা যাক। শাওমি নোট সিরিজের ফোন বের করে এদের রেডমি নামে সাব ব্যান্ড৷ এদের কাজ হল এই নোট সিরিজ নিয়ে কাজ করা৷ প্রতিবছর নোট সিরিজের ১/২ টা ফোন বাজারে আসে। সাথে সেই ফোন গুলার বিভিন্ন ভার্সন (যেমন - র‍্যাম ও রমের ভিত্তিতে) বাজারে আসে। এই বছরও তারা রেডমি সিরিজের নোট ৯ বাজারে আনে। এই বছর হয়তো এই সিরিজের আরো ফোন বাজারে আসবে। ডিস্পলেঃ ফোনটির ডিসপ্লে সাইজ ৬.৫৩ ইঞ্চি। এতে আইপিএস এলসিডি ডিসপ্লে ব্যবহার করা হয়েছে। এই ফোনের ডিসপ্লে প্রটেকশন হিসেবে আছে গরিলা গ্লাস ফাইভ। স্ক্রিন আর ফোনের বডির অনুপাত প্রায় ৮৩.৫%। এই ফোনের ডিসপ্লে ফুলএইচডি মানে ১০৮০পি। এই ডিস্পলের দৈর্ঘ্য ১৯.৫ একক এবং প্রস্থ হল ৯ একক। এত বড় ফোনের কারনে এই ফোনের পিপি আই ডেনসিটি ৩৯৫। যা একটু কম। প্লাটফর্মঃ এই ফোনের অপারেটিং সিস্টেম এন্ড্রয়েড ১০ এবং এর...

তারাবিহ সমগ্র - প্রথম আলো

রামাদান ২০২৪ উপলক্ষে প্রথম আলোর নিয়মিত আয়োজন - খতমে তারাবিহ'র সূরা গুলো নিয়ে সংক্ষিপ্ত আলোচনা'র লিংক  নিচে দেওয়া হলো।  লিংকে ক্লিক করলেই আপনাকে আলোচনা তে নিয়ে যাবে। তারাবিহ: ১ | একটি খুন ও গাভি নিয়ে বনি ইসরাইলের বাড়াবাড়ি তারাবিহ: ২ | নারীর মর্যাদা ও অধিকার এবং অলৌকিক তিন ঘটনা তারাবিহ: ৩ | যে ১৪ নারীকে বিয়ে করা হারাম তারাবিতে: ১২ | মহানবী (সা.)–এর আকাশভ্রমণ এবং আসহাবে কাহাফের কাহিনি