链栈的实现(加析构、重载、拷贝安全机制)

 

Seq_stack.h:

 

 

[cpp] view plain copy print?

  1. /*============================================================================= 
  2. #      Author: liangshu - cbam  
  3. #      QQ : 756029571  
  4. #      School : 哈尔滨理工大学  
  5. #      Last modified: 2015-10-26 20:34 
  6. #     Filename: 链栈的实现 - 副本 (4).cpp 
  7. #     Description:  
  8. #        The people who are crazy enough to think they can change the world, are the ones who do !  
  9. =============================================================================*/  
  10. #  
  11. using namespace std;  
  12. typedef int Node_entry;  
  13. typedef int Stack_entry;  
  14. enum Error_code {overflow, underflow, success};  
  15. struct Node{  
  16.   Node_entry Entry;  
  17.   Node *next;  
  18.   Node();  
  19.   Node(Node_entry item, Node *add_on = NULL)//:Entry(item), next(NULL){}  
  20.   {  
  21.       Entry = item;  
  22.       next = add_on;  
  23.   }  
  24. };  
  25.   
  26. class Stack{  
  27.   public:  
  28.       Stack();  
  29.       bool Empty()const;  
  30.       Error_code Push(const Stack_entry &item);  
  31.       Error_code Pop();  
  32.       Error_code Top(Stack_entry &item)const;  
  33.       void operator = (const Stack &original);  
  34.       Stack(const Stack &original);  
  35.       void Print_stack()const;  
  36.       ~Stack();  
  37.   protected:  
  38.     Node*top_node;  
  39. };  
  40.   
  41. Node::Node(){  
  42.   next = NULL;  
  43. }  
  44. Stack::Stack(){  
  45.   top_node = NULL;  
  46. }  
  47. bool Stack :: Empty()const{  
  48.   if(top_node == NULL){  
  49.     return true;  
  50.   }  
  51.   return false;  
  52. }  
  53. Error_code Stack::Push(const Stack_entry &item){  
  54.   Node *new_top = new Node(item, top_node);  
  55.   if(new_top == NULL){  
  56.     return overflow;  
  57.   }  
  58.   top_node = new_top;  
  59.   return success;  
  60. }  
  61.   
  62. Error_code Stack::Pop(){  
  63.   Node *old_top = top_node;  
  64.   if(top_node == NULL){  
  65.     return underflow;  
  66.   }  
  67.   top_node = top_node -> next;  
  68.   delete old_top;  
  69.   return success;  
  70. }  
  71. Error_code Stack::Top(Stack_entry &item)const{  
  72.    if(top_node == NULL){  
  73.     return underflow;  
  74.    }  
  75.    item = top_node -> Entry;  
  76.    return success;  
  77. }  
  78. void Stack::operator = (const Stack &original){  
  79.   Node *new_top, *new_copy, *original_node = original.top_node;  
  80.   if(original_node == NULL){  
  81.     new_top = NULL;  
  82.   }  
  83.   else{  
  84.     new_top = new_copy = new Node(original_node -> Entry);  
  85.     while(original_node -> next != NULL){  
  86.         original_node = original_node -> next;  
  87.         new_copy -> next = new Node(original_node -> Entry);  
  88.         new_copy = new_copy -> next;  
  89.     }  
  90.   }  
  91.   //最好清空调用对象,然后再给他挂上栈顶指针。  
  92.   while(! Empty()){  
  93.     Pop();  
  94.   }  
  95.   top_node = new_top;  
  96. }  
  97.   
  98. Stack::Stack(const Stack &original){  
  99.   Node *new_copy, *original_node = original.top_node;  
  100.   if(original_node == NULL){  
  101.      top_node = NULL;  
  102.   }  
  103.   else{  
  104.     top_node = new_copy = new Node(original_node -> Entry);  
  105.     while(original_node -> next != NULL){  
  106.         original_node = original_node -> next;  
  107.         new_copy -> next = new Node(original_node -> Entry);  
  108.         new_copy = new_copy -> next;  
  109.     }  
  110.   }  
  111. }  
  112.   
  113. void Stack::Print_stack()const{  
  114.   Node *new_top = top_node;  
  115.   cout<<"top <- ";  
  116.   while(new_top != NULL){  
  117.         cout<<new_top -> Entry<<" <- ";  
  118.     new_top = new_top -> next;  
  119.   }  
  120.   cout<<"bottom"<<endl;  
  121. }  
  122.   
  123. //以下两个析构函数从意义上来说是一样的  
  124. //一个栈对象为空,意味着数据成员top_node == NULL.  
  125. Stack::~Stack(){  
  126.    while(top_node != NULL){  
  127.       Pop();  
  128.    }  
  129. }  
  130. Stack::~Stack(){  
  131.    while(!Empty()){  
  132.     Pop();  
  133.    }  
  134. }  


Test.cpp:

 

[cpp] view plain copy print?

  1. #  
  2. #include<iostream>  
  3. #include"Seq_stack.h"  
  4. using namespace std;  
  5. void test(Stack &stack_copy){  
  6.   stack_copy.Print_stack();  
  7. }  
  8. int main(){  
  9.    Stack stack_1, stack_2, stack_3, stack_4;  
  10.    for(int i = 1; i <= 4; i++){  
  11.        stack_1.Push(i);  
  12.    }  
  13.    stack_1.Print_stack();  
  14.    int x;stack_1.Top(x);  
  15.    cout<<x<<endl;  
  16.    stack_1.Pop();  
  17.    stack_1.Top(x);  
  18.    cout<<x<<endl;  
  19.    stack_2 = stack_1;  
  20.    stack_1.Print_stack();  
  21.    stack_2.Print_stack();  
  22.    stack_3 = stack_2;//调用重载函数(完全拷贝)  
  23.    test(stack_3);  
  24.    stack_4 = Stack(stack_2);//调用拷贝构造函数(完全拷贝)  
  25.    stack_4.Print_stack();  
  26.    return 0;  

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值