Min Stack

Min Stack

Design a stack that supports push, pop, top, and retrieving(检索) the minimum element in constant time.

push(x) — Push element x onto stack.

pop() — Removes the element on top of the stack.

top() — Get the top element.

getMin() — Retrieve(取回) the minimum element in the stack.

分析:设计一个堆栈支持push,pop,top以及以常数时间检索里面的最小元素

思路:

 1、用两个stack来解决:第一个stack用来正常进行stack的push,pop和top操作;另外一个min_stack用来存储最小元素.每次对stack进行pop或者push时,也对min_stack进行相应操作。

2、 第二个min_stack可以进行优化:不一定每个最小元素都要入栈min_stack, push的时候,只入栈比当前min小或者相等的值就可以了。pop的时候,要比较待pop元素和min_stack中top的大小。如果待pop元素和min_stack的top元素相等,则将min stack进行pop。

代码如下:

class MinStack {  
private:  
    std::stack<int> stack;  
    std::stack<int> min_stack;  
public:  
    void push(int x) {  
        stack.push(x);  
        if (min_stack.empty() || ((!min_stack.empty()) && x <= min_stack.top())) {  //NOTE: 是“小于等于”,不是“小于”  
            min_stack.push(x);  
        }  
    }  
      
    void pop() {  
        if (!stack.empty()) {  
            if (stack.top() == min_stack.top())  
                min_stack.pop();  
            stack.pop();  
        }  
    }  
      
    int top() {  
        if (!stack.empty())  
            return stack.top();  
    }  
      
    int getMin() {  
        if (!min_stack.empty())  
            return min_stack.top();  
    }  
};  

 或:

class MinStack {
public:
    void push(int x) {
        if (stk1.empty() || x <= stk2.top())
            stk2.push(x);
        stk1.push(x);
    }

    void pop() {
        if (stk1.top() == stk2.top())
            stk2.pop();
        stk1.pop();
    }

    int top() {
        return stk1.top();
    }

    int getMin() {
        return stk2.top();
    }
private:
    stack<int> stk1; 
    stack<int> stk2;
};

  或者:using two vectors

class MinStack {
public:
    vector<int> stack; 
    vector<int> stmin = {INT_MAX};
    void push(int x) {
        if(x <= stmin[stmin.size() - 1]) stmin.push_back(x);
        stack.push_back(x);
    }

    void pop() {
        if(stack[stack.size() - 1] == stmin[stmin.size() - 1]) stmin.pop_back();
        stack.pop_back();
    }

    int top() {
        if(stack.size() == 0) return 0;
        return stack[stack.size() - 1];
    }

    int getMin() {
        return stmin[stmin.size() - 1];
    }
}; 

  

转载于:https://www.cnblogs.com/carsonzhu/p/4684558.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/109380.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 博客日记目录[通俗易懂]

    博客日记目录[通俗易懂]用于整理博客,清晰记录发文过程2022年1月18日目录2022年1月2022年1月2022年1月20日【修改】Spring框架概述【补充】IOC操作Bean管理2022年1月19日【修改】Spring框架概述【补充】IOC操作Bean管理(xml)【修改】IDEA错误Nomainclassspecified【补充】新增视频版2022年1月18日【修改】Spring框架概述【补充】IOC操作Bean管理(xml)…

    2022年6月8日
    80
  • 价值3888开源企业发卡网源码/全网对接/全新UI风格/完美运营

    价值3888开源企业发卡网源码/全网对接/全新UI风格/完美运营介绍:系统是全开源的,功能很多就不一一介绍了,喜欢就拿走,互站上卖3888免费开源,100%能搭建!老米发卡系统功能亮点介绍:1:已接入易支付接口/支持qq/微信/支付宝2:全网商品对接,店铺对接一秒完成对接,!3:商品池系统/供货系统/代理系统/对接码对接商品4:店铺音乐支付接口/缩我短网址接口/销售模版主题设置5:后台新增一键添加支付接口/商品池权限/推荐商品权限/商家保证金6:平均有15套pc售卡模版,3套手机售卡模版7:一些系统还带有后门,我这个系统完全无后门8:本系统不敢说全

    2022年7月14日
    18
  • 使用jdbc连接mysql数据库_mysql允许远程连接

    使用jdbc连接mysql数据库_mysql允许远程连接JDBC(JavaDatabaseConnectivity,Java数据库连接)是Java语言中用来规范客户端程序如何来访问数据库的应用程序接口,提供了诸如查询和更新数据库中数据的方法。本文讲述如何使用JDBC来连接和访问数据库。为方便引入JDBC依赖包,我们创建Maven项目来实现我们的示例程序。打开IntelliJIDEA客户端,File-New-…

    2022年9月4日
    3
  • 工作流初始错误 泛微提交流程提示_泛微OA 工作流WebService接口使用说明[通俗易懂]

    工作流初始错误 泛微提交流程提示_泛微OA 工作流WebService接口使用说明[通俗易懂]工作流WebService接口使用说明一、检查部署是否成功:输入下面的地址http://192.168.4.183(换成实际的地址):8060(实际的端口号)/services/,界面中有如下服务即可:采用WebServerice技术进行协同系统和业务系统进行数据交互,由协同系统方开发实现WebServerice服务,业务系统方需在本地实现WebServerice本地代理来进行调用。…

    2022年6月23日
    37
  • 一个新的敲诈者病毒

    一个新的敲诈者病毒

    2021年7月23日
    66
  • tomcat突然宕机问题解决方案

    tomcat突然宕机问题解决方案一.tomcat突然宕机时间2019年10月19号8点30分51秒,xxxx系统生产环境的92机器出现tomcat突然宕机问题。二.问题定位1.排查tomcat的启停日志。在文件tomcat/logs/localhost.xxxx.log,排查tomcat的启停日志正常。在宕机时刻,有关闭日志输出。2.使用history命令,查看系统的操作命令。发现使用‘./bi…

    2022年7月26日
    31

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号