C++ Program Code to implement the concept of doubly linked list, utilizing the concept of template class

/* The following C++ Program Code is used to implement the concept of doubly linked list. The program also utilizes the concept of template classes in order to have inter-compatibility for various data types. The user at the starting creates a linked list, & to get the other options he should enter the element as '0'. Then the program gives option to delete, insert, & display the linked list element. */

#include<iostream>
#include<conio.h>
using namespace std;
#define double Double


template<class T>
class node
{
      public:
             T data;
             node *l,*r;
};


template<class T>
class double
{
      private:
              node<T> *first;
      public:
             double()
             {
                     first==NULL;
             }
             void createlist();
             void del();
             void insert();
             void disp();
};


template<class T>
void double<T>::createlist()
{
     int a;
     node<T> *cur,*ptr;
     first=NULL;
     cout<<"\nEnter data for new node : ";
     cin>>a;
     while(a)
     {
             cur=new node<T>;
             cur->data=a;
             cur->l=cur->r=NULL;
             if(first==NULL)
             {
                            first=cur;
             }
             else
             {
                 cur->l=ptr;
                 ptr->r=cur;
             }
             ptr=cur;
             cout<<"\nEnter data of node : ";
             cin>>a;
     }
}


template<class T>
void double<T>::disp()
{
     node<T> *ptr,*last;
     ptr=first;
     last=NULL;
     cout<<"\nThe list is\n";
     while(ptr!=NULL)
     {
                     cout<<ptr->data<<"\t";
                     if(ptr->r==NULL)
                     last=ptr;
                     ptr=ptr->r;
     }
     cout<<"\nThe reverse list is\n";
     ptr=last;
     while(ptr!=NULL)
     {                 
                     cout<<ptr->data<<"\t";
                     ptr=ptr->l;
     }
}


template<class T>
void double<T>::insert()
{
     T ele;
     char ch;
     node<T> *ptr,*cur;
     ptr=first;
     cur=new node<T>;
     cout<<"Enter data for the node:";
     cin>>cur->data;
     cur->r=cur->l=NULL;
     cout<<"Do u want to insert at first place [y/n]:";
     cin>>ch;
     if(ch=='y'||ch=='Y')
     {
                         ptr->l=cur;
                         cur->r=ptr;
                         first=cur;
     }
     else
     {
         cout<<"After which element you want to insert? : ";
         cin>>ele;
         while(ptr!=NULL)
         {
                         if(ptr->data==ele)
                         {
                                           cur->r=ptr->r;
                                           cur->l=ptr;
                                           ptr->r->l=cur;
                                           ptr->r=cur;
                                           break;
                         }
                         else
                         {
                             ptr=ptr->r;
                         }
         }
     }
}


template<class T>
void double<T>::del()
{
     T ele;
     char ch;
     node<T> *ptr;
     ptr=first;
     cout<<"Do you want to delete first element[y/n]? : ";
     cin>>ch;
     if(ch=='y'||ch=='Y')
     {
                         ptr->r->l=NULL;
                         first=ptr->r;
     }
     else
     {
         cout<<"\nEnter the element you want to delete : ";
         cin>>ele;
         while(ptr!=NULL)
         {
                         if(ptr->data==ele)
                         {
                                           ptr->r->l=ptr->l;
                                           ptr->l->r=ptr->r;
                                           break;
                         }
                         else
                         {
                             ptr=ptr->r;
                         }
         }
     }
}


void main()
{
    int ch;
    double<int> d;
    d.createlist();
    do
    {
                   cout<<"\n 1.Insert \n 2.Delete \n 3.Display \n 4.Exit \n";
                   cout<<"Enter choice : ";
                   cin>>ch;
                   switch(ch)
                   {
                             case 1: d.insert();
                             break;
                             case 2: d.del();
                             break;
                             case 3: d.disp();
                             break;
                             case 4:exit(0);
                             break;
                             default: cout<<"\nWrong choice!";
                   }
    }while(ch<=4);
    system("pause");
}


Screenshot:
C++ Program Code to implement the concept of doubly linked list, utilizing the concept of template class

No comments:

Post a Comment