温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

C++中如何使用链栈模板

发布时间:2021-07-19 17:51:48 来源:亿速云 阅读:144 作者:Leah 栏目:编程语言

本篇文章给大家分享的是有关C++中如何使用链栈模板,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。

C++链栈模板声明

template <class T> struct StackNode  {  T typeData;  StackNode *nextNode;  };  template <class T> class DZ_Stack   {  public:  bool Push(const T data);  bool Pop(T& data);   bool Peek(T& data);  bool IsEmpty();   DZ_Stack();  virtual ~DZ_Stack();  private:  StackNode<T> *pStackTop;  int iNodeCount;  };

C++链栈模板实现

  1. template <class T> 

  2. DZ_Stack<T>::DZ_Stack()  

  3. {  

  4. pStackTop=NULL;  

  5. iNodeCount=0;  

  6. }  

  7. template <class T> 

  8. DZ_Stack<T>::~DZ_Stack()  

  9. {  

  10. while(!IsEmpty())  

  11. {  

  12. StackNode<T> *pStackNode= pStackTop;  

  13. pStackToppStackTop=pStackTop->nextNode;  

  14. delete (pStackNode);  

  15. pStackNode=NULL;  

  16. }  

  17. pStackTop=NULL;  

  18. }  

  19. template <class T> 

  20. bool DZ_Stack<T>::Push(const T data)  

  21. {   

  22. StackNode<T> *pStackNode=new StackNode<T>;  

  23. if( NULL == pStackNode )   

  24. return false;  

  25. pStackNode->typeData=data;  

  26. pStackNode->nextNode=pStackTop;  

  27. pStackTop=pStackNode;  

  28. iNodeCount++;  

  29. return true;  

  30. }  

  31. template <class T> 

  32. bool DZ_Stack<T>::Pop(T& data)  

  33. {   

  34. if ( IsEmpty() )  

  35. return false;  

  36. data=pStackTop->typeData;  

  37. StackNode<T> *pStackNode= pStackTop;  

  38. pStackToppStackTop=pStackTop->nextNode;  

  39. delete (pStackNode);  

  40. iNodeCount--;  

  41. return true;   

  42. }  

  43. template <class T> 

  44. bool DZ_Stack<T>::Peek(T& data)  

  45. {   

  46. if (IsEmpty())  

  47. return false;  

  48. data=pStackTop->typeData;  

  49. return true;   

  50. }  

  51. template <class T> 

  52. bool DZ_Stack<T>::IsEmpty()  

  53. {   

  54. if ( NULL == pStackTop )  

  55. return true;  

  56. else  

  57. return false;  

  58. }  

  59. #endif // !defined(AFX_DZ_STACK_H__10036803_D752_4EF7_
    852D_DD6B377D7AB9__INCLUDED_) 

以上就是C++中如何使用链栈模板,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注亿速云行业资讯频道。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

c++
AI