Advertisement
Guest User

Untitled

a guest
Jun 23rd, 2017
56
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 2.26 KB | None | 0 0
  1. #include <iostream>
  2. using namespace std;
  3. #include<string>
  4. #include<cassert>
  5.  
  6. template <typename T>
  7. class Linked{
  8. private:
  9.     struct node
  10.     {
  11.         int data;
  12.         node*next; 
  13.     }*p;
  14.     T element;
  15.     int go;
  16. public:
  17.     Linked(const Linked<T>& l);
  18.     Linked(int go);
  19.     void append(T num);
  20.     void addFirst(T num);
  21.     void addAfter(int c, T num);
  22.     void del(T num);//Deletion
  23.     void display();//Display
  24.     int count();
  25.     ~Linked();//Destructor
  26. };
  27. template<typename T>
  28. Linked<T>::Linked(int go){
  29.     p=NULL;
  30. }
  31. template<typename T>
  32. Linked<T>::Linked(const Linked<T>&l){
  33.     p=NULL;
  34. }
  35. template<typename T>
  36. void Linked<T>::append(T num)
  37. {
  38.      node *q,*t;
  39.    if( p == NULL ){
  40.       p = new node;
  41.       p->data = num;
  42.       p->next = NULL;
  43.    }
  44.    else{
  45.         q = p;
  46.         while( q->next != NULL )
  47.             q = q->next;
  48.             t = new node;
  49.             t->data = num;
  50.             t->next = NULL;
  51.             q->next = t;
  52.    }
  53. }
  54. template<typename T>
  55. void Linked<T>::addFirst(T num){
  56.     node *q;
  57.     q = new node;
  58.     q->data = num;
  59.     q->next = p;
  60.     p = q;
  61. }
  62.  
  63. template<typename T>
  64. void Linked<T>::addAfter( int c, T num)
  65. {
  66.      node *q,*t;
  67.    int i;
  68.    for(i=0,q=p;i<c;i++)
  69.    {
  70.         q = q->next;
  71.       if( q == NULL )
  72.       {
  73.            cout<<"\nThere are less than "<<c<<" elements.";
  74.          return;
  75.       }
  76.    }
  77.  
  78.    t = new node;
  79.    t->data = num;
  80.    t->next = q->next;
  81.    q->next = t;
  82. }
  83. template<typename T>
  84. void Linked<T>::del( T num )
  85. {
  86.      node *q,*r;
  87.    q = p;
  88.    if( q->data == num )
  89.    {
  90.         p = q->next;
  91.       delete q;
  92.       return;
  93.    }
  94.  
  95.    r = q;
  96.    while( q!=NULL )
  97.    {
  98.         if( q->data == num )
  99.       {
  100.            r->next = q->next;
  101.          delete q;
  102.          return;
  103.       }
  104.  
  105.       r = q;
  106.       q = q->next;
  107.    }
  108.    cout<<"\nElement "<<num<<" not Found.";
  109. }
  110. template<typename T>
  111. void Linked<T>::display()
  112. {
  113.      node *q;
  114.    cout<<endl;
  115.  
  116.    for( q = p ; q != NULL ; q = q->next )
  117.         cout<<endl<<q->data;
  118.  
  119. }
  120. template<typename T>
  121. int Linked<T>::count()
  122. {
  123.      node *q;
  124.    int c=0;
  125.    for( q=p ; q != NULL ; q = q->next )
  126.         c++;
  127.  
  128.    return c;
  129. }
  130. template<typename T>
  131. Linked<T>::~Linked()
  132. {
  133.     node *q;
  134.    if( p == NULL )
  135.         return;
  136.  
  137.    while( p != NULL )
  138.    {
  139.         q = p->next;
  140.       delete p;
  141.       p = q;
  142.    }
  143. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement