হিপ এর অ্যাপ্লিকেশন: প্রাইমারি এলিমেন্ট সার্চ, হাফম্যান কোডিং

Computer Science - ডাটা স্ট্রাকচার & অ্যালগরিদম (Data Structure & Algorithms) - বাইনারি হিপ (Binary Heap)
157

হিপ (Heap) এর অ্যাপ্লিকেশন

হিপ হল একটি বিশেষ ধরনের বাইনারি ট্রি যা পূর্ণ বা পারেন্ট নোডের মান সবসময় তার চাইল্ড নোডের মানের চেয়ে বড় (ম্যাক্স হিপ) বা ছোট (মিন হিপ) থাকে। এটি বিভিন্ন অ্যাপ্লিকেশনে ব্যবহৃত হয়, যেমন প্রাইমারি এলিমেন্ট সার্চ এবং হাফম্যান কোডিং।

১. প্রাইমারি এলিমেন্ট সার্চ (Priority Queue)

বর্ণনা

প্রাইমারি এলিমেন্ট সার্চ হল একটি ডেটা স্ট্রাকচার যা এলিমেন্টগুলিকে তাদের প্রাধান্য অনুযায়ী সজ্জিত করে। হিপ ব্যবহার করে প্রাইমারি কিউ তৈরি করা হয়, যেখানে এলিমেন্টগুলি তাদের প্রাধান্যের ভিত্তিতে ইনসার্ট এবং এক্সট্র্যাক্ট করা হয়।

উদাহরণ

  1. মিন হিপ: সর্বনিম্ন প্রাধান্যের এলিমেন্ট সর্বদা হিপের শীর্ষে থাকে।
  2. ম্যাক্স হিপ: সর্বাধিক প্রাধান্যের এলিমেন্ট সর্বদা হিপের শীর্ষে থাকে।

ব্যবহার

  • ডাটাবেসের অর্ডারিং: প্রাইমারি কিউ ব্যবহার করে ডেটাবেসে রেকর্ডগুলিকে প্রাধান্যের ভিত্তিতে সনাক্ত করা।
  • অ্যাপ্লিকেশন: কাজের তালিকা তৈরি করা যেখানে উচ্চ প্রাধান্যের কাজগুলি প্রথমে সম্পন্ন করতে হয়।

উদাহরণ কোড (Python):

import heapq

# মিন হিপ ব্যবহার করে প্রাইমারি কিউ তৈরি করা
priority_queue = []

# এলিমেন্ট যুক্ত করা
heapq.heappush(priority_queue, (2, 'task2'))
heapq.heappush(priority_queue, (1, 'task1'))
heapq.heappush(priority_queue, (3, 'task3'))

# এলিমেন্ট বের করা
while priority_queue:
    print(heapq.heappop(priority_queue)[1])  # Output: task1, task2, task3

২. হাফম্যান কোডিং (Huffman Coding)

বর্ণনা

হাফম্যান কোডিং হল একটি প্রকারের ডেটা সংকোচনের অ্যালগরিদম যা ট্রি ব্যবহার করে বিভিন্ন অক্ষরের জন্য কোড তৈরি করে। হাফম্যান অ্যালগরিদমের সময় হিপ ব্যবহার করা হয় অক্ষরের প্রাধান্য অনুযায়ী।

পদ্ধতি

  1. অক্ষরের ফ্রিকোয়েন্সি অনুযায়ী একটি মিন হিপ তৈরি করুন।
  2. হিপের দুটি সর্বনিম্ন ফ্রিকোয়েন্সি নোড নিয়ে একটি নতুন নোড তৈরি করুন এবং সেটিকে হিপে পুনরায় যুক্ত করুন।
  3. এই প্রক্রিয়া চলতে থাকবে যতক্ষণ না হিপে একটি মাত্র নোড থাকে, যা হাফম্যান ট্রি হিসেবে কাজ করবে।

ব্যবহার

  • ডেটা সংকোচন: হাফম্যান কোডিং ব্যবহার করে টেক্সট ফাইল এবং অন্যান্য ডেটাকে সংকুচিত করা।

উদাহরণ কোড (Python):

import heapq
from collections import defaultdict

class Node:
    def __init__(self, char, freq):
        self.char = char
        self.freq = freq
        self.left = None
        self.right = None

    def __lt__(self, other):
        return self.freq < other.freq

def huffman_coding(frequencies):
    heap = []
    
    # নোড তৈরি করা
    for char, freq in frequencies.items():
        heapq.heappush(heap, Node(char, freq))

    while len(heap) > 1:
        left = heapq.heappop(heap)
        right = heapq.heappop(heap)
        merged = Node(None, left.freq + right.freq)
        merged.left = left
        merged.right = right
        heapq.heappush(heap, merged)

    return heap[0]  # হাফম্যান ট্রি

# উদাহরণ
frequencies = {'A': 5, 'B': 9, 'C': 12, 'D': 13, 'E': 16, 'F': 45}
huffman_tree = huffman_coding(frequencies)

উপসংহার

হিপ হল একটি শক্তিশালী ডেটা স্ট্রাকচার যা বিভিন্ন অ্যাপ্লিকেশনে ব্যবহৃত হয়, যেমন প্রাইমারি এলিমেন্ট সার্চ এবং হাফম্যান কোডিং। এটি ডেটার প্রাধান্য অনুযায়ী ব্যবস্থাপনা এবং সংকোচনের কার্যকরী কৌশল সরবরাহ করে, যা সফটওয়্যার উন্নয়নের ক্ষেত্রে গুরুত্বপূর্ণ।

Promotion
NEW SATT AI এখন আপনাকে সাহায্য করতে পারে।

Are you sure to start over?

Loading...