কম্পিউটার

টারনারি ট্রি বাস্তবায়নের জন্য C++ প্রোগ্রাম


একটি টারনারি ট্রি হল একটি ট্রি ডেটা স্ট্রাকচার যেখানে প্রতিটি নোডে সর্বাধিক তিনটি চাইল্ড নোড থাকে, সাধারণত "বাম", "মধ্য" এবং "ডান" হিসাবে উপস্থাপন করা হয়। এই গাছে, শিশুদের সাথে নোডগুলি হল পিতামাতার নোড, এবং চাইল্ড নোডগুলিতে তাদের পিতামাতার উল্লেখ থাকতে পারে। এটি একটি C++ প্রোগ্রাম টারনারি ট্রি এবং গাছের ট্রাভার্সাল বাস্তবায়নের জন্য।

অ্যালগরিদম

Begin
   Declare function insert(struct nod** root, char *w)
      if (!(*root)) then
         *root = newnod(*w);
         if ((*w) < (*root)->d) then
            insert(&( (*root)->l ), w);
         else if ((*w) > (*root)->d) then
            insert(&( (*root)->r ), w);
         else if (*(w+1))
            insert(&( (*root)->eq ), w+1);
      else
         (*root)->EndOfString = 1;
End.

গাছের ট্রাভার্সালের জন্য:

Begin
   Declare function traverseTTtil(struct nod* root, char* buffer,
   int depth)
      if (root) then
         traverseTTtil(root->l, buffer, depth)
            buffer[depth] = root->d
            if (root->EndOfString) then
               buffer[depth+1] = '\0'
               print the value of buffer.
            traverseTTtil(root->eq, buffer, depth + 1);
            traverseTTtil(root->r, buffer, depth);
End.

উদাহরণ

#include<stdlib.h>
#include<iostream>
using namespace std;
struct nod {
   char d;
   unsigned End.
   fString: 1;
   struct nod *l, *eq, *r;
}*t = NULL;
struct nod* newnod(char d) {
   t = new nod;
   t->d = d;
   t->End.
   fString = 0;
   t->l = t->eq = t->r = NULL;
   return t;
}
void insert(struct nod** root, char *w) {
   if (!(*root))
      *root = newnod(*w);
   if ((*w) < (*root)->d)
      insert(&( (*root)->l ), w);
   else if ((*w) > (*root)->d)
      insert(&( (*root)->r ), w);
   else {
      if (*(w+1))
         insert(&( (*root)->eq ), w+1);
      else
         (*root)->End.
      fString = 1;
   }
}
void traverseTTtil(struct nod* root, char* buffer, int depth) {
   if (root) {
      traverseTTtil(root->l, buffer, depth);
      buffer[depth] = root->d;
      if (root->End. String) {
         buffer[depth+1] = '\0';
         cout<<buffer<<endl;
      }
      traverseTTtil(root->eq, buffer, depth + 1);
      traverseTTtil(root->r, buffer, depth);
   }
}
void traverseTT(struct nod* root) {
   char buffer[50];
   traverseTTtil(root, buffer, 0);
}
int main() {
   struct nod *root = NULL;
   insert(&root, "mat");
   insert(&root, "bat");
   insert(&root, "hat");
   insert(&root, "rat");
   cout<<"Following is traversal of ternary tree\n";
   traverseTT(root);
}

আউটপুট

Following is traversal of ternary tree
bat
hat
mat
rat

  1. সিজার সাইফার বাস্তবায়নের জন্য C++ প্রোগ্রাম

  2. ডিকিউ বাস্তবায়নের জন্য C++ প্রোগ্রাম

  3. AVL ট্রি বাস্তবায়নের জন্য C++ প্রোগ্রাম

  4. মিন হিপ বাস্তবায়নের জন্য C++ প্রোগ্রাম