বাইনারি ট্রি, বাইনারি সার্চ ট্রি (BST), AVL ট্রি

ট্রিস (Trees) - ডাটা স্ট্রাকচার & অ্যালগরিদম (Data Structure & Algorithms) - Computer Science

402

বাইনারি ট্রি, বাইনারি সার্চ ট্রি (BST), এবং AVL ট্রি হল ডেটা স্ট্রাকচারের বিভিন্ন ধরনের গঠন যা গাণিতিক এবং কম্পিউটার বিজ্ঞানে ব্যবহৃত হয়। প্রতিটি ট্রির নিজস্ব বৈশিষ্ট্য, কার্যকরীতা এবং ব্যবহারের ক্ষেত্র রয়েছে। নিচে এই তিনটি ট্রির বিস্তারিত আলোচনা করা হলো।

১. বাইনারি ট্রি (Binary Tree)

বিবরণ: বাইনারি ট্রি হল একটি ট্রি ডেটা স্ট্রাকচার যেখানে প্রতিটি নোডের সর্বাধিক দুটি সন্তান (child) থাকতে পারে। প্রতিটি নোডে একটি মান (value) এবং দুটি পয়েন্টার থাকে: একটি বাম সন্তানের জন্য এবং একটি ডান সন্তানের জন্য।

বৈশিষ্ট্য:

  • প্রতিটি নোডে 0, 1, বা 2 সন্তান থাকতে পারে।
  • বাইনারি ট্রি গভীরতা নির্ভর করে কতগুলি স্তর রয়েছে।
  • বিভিন্ন বাইনারি ট্রির ব্যবহার হতে পারে, যেমন পূর্ণ বাইনারি ট্রি, সম্পূর্ণ বাইনারি ট্রি, এবং সাধারণ বাইনারি ট্রি।

উদাহরণ:

       A
      / \
     B   C
    / \
   D   E

২. বাইনারি সার্চ ট্রি (Binary Search Tree - BST)

বিবরণ: বাইনারি সার্চ ট্রি একটি বিশেষ ধরনের বাইনারি ট্রি, যেখানে প্রতিটি নোডের বাম সন্তানের মান উক্ত নোডের মানের চেয়ে ছোট এবং ডান সন্তানের মান উক্ত নোডের মানের চেয়ে বড়। এটি ডেটা অনুসন্ধান, ইনসার্ট এবং ডিলিট করার জন্য কার্যকরী।

বৈশিষ্ট্য:

  • ইনসার্ট, অনুসন্ধান, এবং ডিলিট অপারেশনের জন্য গড় সময় O(log n)।
  • ইন-অর্ডার ট্রাভার্সাল করলে BST এর এলিমেন্টগুলি ক্রমবর্ধমানভাবে পাওয়া যায়।

উদাহরণ:

       10
      /  \
     5    15
    / \   / \
   3   7 12  20

৩. AVL ট্রি (AVL Tree)

বিবরণ: AVL ট্রি একটি ব্যালেন্সড বাইনারি সার্চ ট্রি, যেখানে প্রতিটি নোডের বাম ও ডান subtree এর উচ্চতার মধ্যে সর্বাধিক 1-এর পার্থক্য থাকে। এটি ডেটার কার্যকরী সঞ্চয় নিশ্চিত করে এবং দ্রুত অনুসন্ধান ও ইনসার্টের জন্য পরিচিত।

বৈশিষ্ট্য:

  • ব্যালেন্সিং: AVL ট্রি ইনসার্ট বা ডিলিট করার পর, যদি কোন নোডের ব্যালেন্স ফ্যাক্টর 1, 0, বা -1 এর বাইরে চলে যায়, তবে তা পুনর্বিন্যাস করা হয়।
  • গড় সময় O(log n) অনুসন্ধান, ইনসার্ট, এবং ডিলিটের জন্য।

উদাহরণ:

       30
      /  \
     20   40
    / \    \
   10  25   50

সারসংক্ষেপ

বাইনারি ট্রি: একটি সাধারণ ট্রি ডেটা স্ট্রাকচার, যেখানে প্রতিটি নোডের সর্বাধিক দুটি সন্তান থাকে। এটি বিভিন্ন ট্রাভার্সাল পদ্ধতি (যেমন ইন-অর্ডার, প্রি-অর্ডার, পোস্ট-অর্ডার) মাধ্যমে ব্যবহার করা হয়।

বাইনারি সার্চ ট্রি (BST): একটি বিশেষ বাইনারি ট্রি, যা ডেটা অনুসন্ধানের জন্য প্রয়োজনীয়। এটি সর্বাধিক দুটি সন্তান ধারণ করে এবং প্রতি নোডের বাম সন্তানগুলি ছোট এবং ডান সন্তানগুলি বড় হয়।

AVL ট্রি: একটি ব্যালেন্সড BST যা নিশ্চিত করে যে গাছের উচ্চতা নিয়ন্ত্রিত থাকে, ফলে সকল অপারেশন (অনুসন্ধান, ইনসার্ট, ডিলিট) কার্যকরভাবে O(log n) সময়ে সম্পন্ন হয়।

এই তিনটি ট্রি ডেটা স্ট্রাকচার বিভিন্ন সমস্যার সমাধানের জন্য ব্যবহার করা হয় এবং তাদের বিভিন্ন বৈশিষ্ট্যের কারণে উপযুক্ত পরিস্থিতিতে সঠিকভাবে নির্বাচন করা প্রয়োজন।

Promotion

Are you sure to start over?

Loading...