剑指offer之面试题21:包含min函数的栈

题目:

成都创新互联公司专注于湛江企业网站建设,成都响应式网站建设,购物商城网站建设。湛江网站建设公司,为湛江等地区提供建站服务。全流程按需网站设计,专业设计,全程项目跟踪,成都创新互联公司专业和态度为您提供的服务

定义栈的数据结构,请在该类型中实现一个能够得到栈最小元素的min函数。

思路一:

通过每次在压入栈顶的元素与当前最小元素相比后,保存一遍最小元素,每次弹出,都弹出两个,这个就能得到栈当前最小元素了

代码:

class Solution {
public:
    void push(int value) {
        
        if(s1.size()==0)
        {
            s1.push(value);
            int min=value;
            s1.push(min);
        }
        else
        {
            int min=s1.top();
            if(value s1;
    
};

思路二:利用两个栈,一个栈用于压入数据,另一个栈用于压入数据时的最小元素。无论最小元素是不是压栈的元素,都保存到第二个栈中

代码:

class Solution {
public:
    void push(int value) 
    {
    	if(s1.size()==0)
        {
            s1.push(value);
            s2.push(value);
        }
        else
        {
            s1.push(value);
            int min=s2.top();
			if(min>value)
            {
                s2.push(value);
            }
            else
            {
                s2.push(min);
            }
        }
    }
    void pop() 
    {
    	if(!s1.empty())
        {
            s1.pop();
            s2.pop();
        }
    }
    int top() {
        return s1.top();
        
    }
    int min() {
        return s2.top();
        
    }
private:
    stack s1,s2;
};

名称栏目:剑指offer之面试题21:包含min函数的栈
分享地址:http://hxwzsj.com/article/gichjo.html

其他资讯

Copyright © 2025 青羊区翔捷宏鑫字牌设计制作工作室(个体工商户) All Rights Reserved 蜀ICP备2025123194号-14
友情链接: 攀枝花网站设计 营销网站建设 定制网站建设 企业网站设计 网站制作 成都模版网站建设 成都商城网站建设 成都网站建设推广 成都响应式网站建设 成都营销网站制作 成都网站制作 手机网站制作设计 四川成都网站建设 成都网站建设 网站设计 网站制作 app网站建设 自适应网站设计 手机网站制作 网站建设公司 品牌网站建设 成都网站制作