C++使用模板实现单链表(类外实现)
2019-04-30 18:02
736 查看
本文实例为大家分享了C++使用模板实现单链表的具体代码,供大家参考,具体内容如下
这一篇可以和上一篇 点击打开链接 模板实现单链表进行对比
看类外实现和类内实现的区别
代码:
#include <iostream> using namespace std; template<typename T> class CLink { public: class Node; CLink();//无参的构造函数 void InsertHead(T data);//头插 void InsertTail(T data);//尾插 void Show();//打印 ~CLink();//析构 Node* Find(T val);//查找 private: class Node { public: Node(T data = 0); ~Node(){} public: T mdata; Node* pnext; }; Node* phead; }; //类外实现无参的构造 template<typename T> CLink<T>::CLink() { phead = new Node(); } //类外实现头插 template<typename T> void CLink<T>::InsertHead(T data) { Node* pNewNode = new Node(data); pNewNode->pnext = phead->pnext; phead->pnext = pNewNode; } //类外实现尾插 template<typename T> void CLink<T>::InsertTail(T data) { Node* pNewNode = new Node(data); Node* pCur = phead; while(pCur->pnext != NULL) { pCur = pCur->pnext; } pCur->pnext = pNewNode; } //类外实现打印函数 template<typename T> void CLink<T>::Show() { Node* pCur = phead->pnext; while (pCur != NULL) { cout << pCur->mdata << " "; pCur = pCur->pnext; } cout << endl; } //类外实现析构函数 template<typename T> CLink<T>::~CLink() { Node* pCur = phead; Node* pNext = phead; while (pCur != NULL) { pNext = pCur->pnext; delete pCur; pCur = pNext; } phead = NULL; } //类外实现结点的构造 template<typename T> CLink<T>::Node::Node(T data) { mdata = data; pnext = NULL; } //类外实现查找函数 template<typename T> typename CLink<T>::Node* CLink<T>::Find(T val) { Node* pCur = phead->pnext; while (pCur != NULL) { if (pCur->mdata == val) { return pCur; } pCur = pCur->pnext; } return pCur; } int main() { CLink<int> link1; CLink<int> link2; for(int i = 0;i < 10;i++) { link1.InsertHead(i + 1); link2.InsertTail(i * 2); } cout << "link1:"; link1.Show(); cout << "link2:"; link2.Show(); link1.Find(10); return 0; }
运行结果:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
相关文章推荐
- 单链表的c++实现,使用模板
- C++使用模板实现简单的singleton
- C++ 使用模板 实现单例模式
- 数据结构学习第一篇--C++实现单链表模板
- C++ 使用模板实现一个List的实例
- 2叉树遍历的递归实现-使用c++模板
- [C++] 利用模板的模板参数实现单链表
- C++入门学习:类模板的使用(函数在类的内外实现的不同)
- 使用C++模板实现不需要IDL的RPC【二】
- C++模板学习之单链表的实现
- C/C++使用模板实现数据栈
- 使用C++的类模板实现Stack类
- 使用模板方法模式实现选择题答题 C++
- 使用C++模板实现的一种单例工厂
- C++使用模板并隐藏实现
- 我用c++实现的模板单链表类.并用一个一元多项式进行测试.
- C++_模板举例_使用模板实现集合类(堆栈)
- 使用C++模板技术实现类的动态注册和获取
- 单链表c++简单模板实现
- C++_模板举例_使用模板实现集合类(堆栈)