利用模板类编写一个程序,实现双向链表的插入、删除、查找、显示的功能。

 #include <iostream>
using namespace std;
template <typename T>
struct Node

{ Node(T& d):c(d),next(0),pref(0){}
 T c;
 Node *next,*pref;
}; // define a struct template

template <typename T>
class List

{ Node<T> *first,*last;
public:
 List();
 void add(T& c);
 void remove(T& c);
 Node<T>* find(T& c);
 void print();
 ~List();
}; // declare a class template

template <typename T>
List<T>::List():first(0),last(0){}
// define struct function of List
template <typename T>
void List<T>::add(T& n)
{ Node<T>* p = new Node<T>(n);
 p->next=first;
 first=p;
 (last ? p->next->pref : last) = p;
} // define member function of List: add(T& n)

template <typename T>
void List<T>::remove(T& n)
{ Node<T>* p = find(n);
 if (p!=0)
  { (p->next ? p->next->pref : last) = p->pref;
   (p->pref ? p->pref->next : first)= p->next;
   delete p;
  }
} // define member function of List: remove(T& n)

template <typename T>
Node<T>* List<T>::find(T& n)
{ for (Node<T>* p=first; p; p=p->next)
   if (p->c==n) return p;
 return 0;
} // define member function of List: find(T& n)

template<typename T>
List<T>::~List()
{ for (Node<T>* p; p=first; delete p)
   first=first->next;
} //define destruct function of List

template <typename T>
void List<T>::print()
{ for (Node<T>* p=first; p; p=p->next)
   cout << p->c << " ";
 cout << "/n";
} // define member function of List: print()

int main()
{ List<int> iList;
 int b1=2, b2=5, b3=9, b4=3;
 iList.add(b1);
 iList.add(b2);
 iList.add(b3);
 iList.add(b4);
 iList.print();
 iList.remove(b2);
 iList.print();
 return 0;
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值