首页 > 编程语言 > 详细

设计一个有getMin功能的栈(C++实现)

时间:2020-07-25 11:54:42      阅读:106      评论:0      收藏:0      [点我收藏+]

代码:

#include <iostream>
#include <stack>
# include <string>
#include <stdexcept>

using namespace std;

class my_stack
{
public:
  my_stack(){};
  ~my_stack(){};
  int my_push(int var);
  int my_pop();
  int getmin();
  bool Empty();
private:
  stack<int> stackdata;
  stack<int> stackmin;
};

//实现代码
int my_stack::my_push(int var)
{
  stackdata.push(var);
  if(stackmin.empty()||stackmin.top()>=var)
       stackmin.push(var);
  
  return 0;
}

int my_stack::my_pop()
{
  if(stackdata.empty()){
        throw runtime_error("Empty Stack!");
      }

  int top_value = stackdata.top();//返回stackdata栈顶元素
  stackdata.pop();//弹出stackdata栈顶元素
 
  return top_value;
  }

int my_stack::getmin()
{
  if(stackmin.empty())
      throw runtime_error("Empty Stack!");
  else
     {
      int min_value = stackmin.top();
   
      return min_value;
     }  
}
bool my_stack::Empty()
{
  if(stackdata.empty())
       return true;
  else
       return false;
}

int main()
{
  my_stack mystack;
  int a[] = {1,3,2,2,1,5};
  for(int i=0;i<6;i++)
  {
    mystack.my_push(a[i]);
  }
  while(!mystack.Empty())
  {
    std::cout <<"this is stack data:"<< mystack.my_pop() << ‘\n‘;
    
  }
  std::cout <<"this is min_data_of_stackdata:"<< mystack.getmin() << ‘\n‘;
  cin.get();
  return 0;
}
结果:
技术分享图片

 

 

设计一个有getMin功能的栈(C++实现)

原文:https://www.cnblogs.com/shiheyuanfang/p/13375223.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!