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

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


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) ইল্লিয়িন হলো সৎকর্মশীলদের (মুমিন ও নেককারদের) আমলনামা সংরক্ষণের স্থান । এটি সপ্তম আসমানের ওপরে সংরক্ষিত এক সম্মানিত স্থান। সূরা আল-মুতাফফিফীন (৮৩:১৮-২১) তে বলা হয়েছে: "كَلَّا إِنَّ كِتَابَ الْأَبْرَارِ لَفِي عِلِّيِّينَ ۝ وَمَا أَدْرَاكَ مَا عِلِّيُّونَ ۝ كِتَابٌ مَرْقُومٌ ۝ يَش...

জাভা ফিডব্যাক এবং স্ট্রাকচার্ড কনকারেন্সি: বিবর্তনের গল্প

Introduction এই ভিডিওর নির্দিষ্ট অংশে জাভা ল্যাঙ্গুয়েজ আর্কিটেক্ট ব্রায়ান গোয়েটজ (Brian Goetz) আলোচনা করেছেন কীভাবে জাভার নতুন ফিচারগুলো তৈরি হয় এবং এতে সাধারণ ডেভেলপারদের মতামতের গুরুত্ব কতটুকু। বিশেষ করে Structured Concurrency -এর মতো জটিল ফিচারগুলো কেন বারবার 'Preview' অবস্থায় থাকে এবং কীভাবে কমিউনিটির ফিডব্যাক সেই ফিচারগুলোকে আরও নিখুঁত করতে সাহায্য করে, তা এখানে সহজভাবে বোঝানো হয়েছে। ১. ভালো ফিডব্যাক আসলে কী? ভিডিও রেফারেন্স: [ 34:53 ] ব্রায়ান গোয়েটজ বলছেন যে, জাভা টিম যখন কোনো নতুন ফিচারের খসড়া (Draft) বা প্রস্তাব (JEP) প্রকাশ করে, তখন তারা এমন কিছু জানতে চায় যা তারা নিজেরা আগে ভাবেনি। বিস্তারিত: একজন ডেভেলপার হিসেবে আমরা যখন কোনো নতুন ফিচার দেখি, আমাদের প্রথম প্রতিক্রিয়া হয় সেটার Syntax বা লেখার ধরন নিয়ে। কিন্তু ব্রায়ানের মতে, "এই লেখাটা কেন এমন হলো?" বা "এটা কোটলিন বা স্কালা-র মতো কেন নয়?"—এই ধরনের ফিডব্যাক খুব একটা কাজে আসে না। আসল দামী ফিডব্যাক হলো সেইটা, যা নতুন কোনো বাস্তব সমস্যা (Edge Case) তুলে ধরে। আমার চিন্তা: আপনি যদি কেবল দ...

[Master Post] Machine Learning for Everybody – Full Course

URL: https://youtu.be/i_LwzRVP7bg?t=0 Title: Machine Learning for Everybody – Full Course Topics:- মেশিন লার্নিংয়ের হাতেখড়ি এবং গুগল কোল্যাব সেটআপ মেশিন লার্নিংয়ের খুঁটিনাটি ও ফিচারের সহজ পাঠ Classification বনাম Regression এবং মডেল ট্রেনিংয়ের সহজ পাঠ মেশিন লার্নিংয়ের জন্য ডেটা তৈরি এবং প্রসেসিং করার সহজ গাইড K-Nearest Neighbors (KNN) থিওরির সহজ পাঠ কে-নিয়ারেস্ট নেইবারস (KNN) ইমপ্লিমেন্টেশন সহজ বাংলায় নেইভ বেইজ থিওরি এবং এর প্রয়োগ: সহজ পাঠ লজিস্টিক রিগ্রেশন: থিওরি ও ইমপ্লিমেন্টেশন SVM থিওরি এবং ইমপ্লিমেন্টেশন সহজ পাঠ নিউরাল নেটওয়ার্ক এবং টেনসরফ্লোর সহজ পাঠ টেনসরফ্লো দিয়ে নিউরাল নেটওয়ার্ক ক্লাসিফিকেশন শেখার সহজ গাইড লিনিয়ার রিগ্রেশন: সহজ কথায় মূল ধারণা ও গণিত লিনিয়ার রিগ্রেশন: সহজ ভাষায় খুঁটিনাটি ও হাতে-কলমে শেখা লিনিয়ার রিগ্রেশন এবং নিউরন মডেলের সহজ পাঠ TensorFlow দিয়ে রিগ্রেশন নিউরাল নেটওয়ার্ক তৈরি - পার্ট ১ টেনসরফ্লো দিয়ে রিগ্রেশন নিউরাল নেটওয়ার্ক তৈরি - পার্ট ২ আনসুপারভাইজড লার্নিং: কে-মিনস ক্লাস্টারিংয়ের সহজ পাঠ Principal C...