题解 | #包含min函数的栈#

包含min函数的栈

http://www.nowcoder.com/practice/4c776177d2c04c2494f2555c9fcc1e49

(1)辅助栈方法

使用两个栈维护数据,一个作为普通栈,一个保存历史最小值


public class Solution {
    //正常栈操作
    private Stack<Integer> stack = new Stack<Integer>();
    //保存最小值栈
    private Stack<Integer> mins = new Stack<Integer>();
    public void push(int node) {
         stack.push(node);
         //最小值栈为空或元素小于最小值栈顶元素则入栈
         if(mins.isEmpty() || node <= mins.peek())
             mins.push(node);
    }
    
    public void pop() {
    	//两个栈顶元素相同则最小值栈顶也需要弹出
         if(stack.peek().equals(mins.peek()))
             mins.pop();
         stack.pop();
    } 
    
    public int top() {
        return stack.peek();
    }
    
    public int min() {
        return mins.peek();
    }
}

(2)记录最小值方法


public class Solution {
    //正常栈操作
    private Stack<Integer> stack = new Stack<Integer>();
    //保存最小值
    int min;
    public void push(int node) {
        if (stack.isEmpty()) {
            min = node;
            stack.push(node - min);
        } else {
        	//栈中存放node-当前最小值的结果
            stack.push(node - min);
            //更新最小值
            if (node > min) {
                min = node;
            }
        }
    }
    
    public void pop() {
        int tmp = stack.pop();
        if (tmp < 0) {
            //出栈时,如果栈顶值大于零,说明上一个最小值和当前一样,不需要变动;
            //如果小于零,则上一个最小值=当前最小值-栈顶值(因为栈顶值=node-min)
            min = min - tmp;
        }
    } 
    
    public int top() {
    	//栈顶小于0,最小值在该位置发生变化,目前最小值为该位置元素值
        if(stack.peek() < 0){
            return min;
        }
        //正常还原元素值
        else{
            return stack.peek() + min;
        }
    }
    
    public int min() {
        return min;
    }
}
全部评论
请问辅助栈解法pop()里面条件判断为什么用equals?不能直接用==判断吗
点赞 回复 分享
发布于 2022-03-04 00:24

相关推荐

秋招投简历提醒助手:个人经验是,一般面二十场左右就会进入侃侃而谈阶段。我今年七月末的时候开始的第一次面试,都是很多不会,回复很慢。后面慢慢迭代,到九月中的时候基本上面啥说啥,很放松的状态
远程面试的尴尬瞬间
点赞 评论 收藏
分享
面试官全程关摄像头1.自我介绍一下2.React和Vue哪个更熟悉一点3.你在之前那段实习经历中有没有什么技术性的突破(我只是实习了44天工作28天,我把我能说的都说了)4.你封装的哪个表单组件支不支持动态传值5.自己在实习阶段Vue3项目封装过hook吗6.hook有什么作用7.Vue2和Vue3的响应式区别(我说一个是proxy是拦截所有的底层操作,Object.defineProperty本身就是一个底层操作,有些东西拦截不了,比如数组的一些操作还有等等,面试官就说实在要拦截能不能拦截????我心想肯定不行呀,他的底层机制就不允许吧)8.pinia和vuex的区别(这个回答不出来是我太久没用了)9.pinia和zustand的区别,怎么选(直接给我干懵了)(我说react能用pinia吗&nbsp;&nbsp;他说要用的话也可以)10.渲染一万条数据,怎么解决页面卡顿问题(我说分页、监听滚轮动态加载,纯数据展示好像还可以用canvas画)(估计是没说虚拟表单,感觉不满意)11.type和interface的区别12.ts的泛型有哪些作用(我就说了一个结构相同但是类型不同的时候可以用,比如请求响应的接口,每次的data不同,这里能用一个泛型,他问我还有什么)13.你项目用的是React,如果让你再写一遍你会选择什么14.pnpm、npm、yarn的区别15.dependencies和devdependencies的区别总而言之太久没面试了,上一段实习的面试js问了很多。结果这次js一点没问,网络方面也没考,表现得很一般,但是知道自己的问题了&nbsp;&nbsp;好好准备,等待明天的影石360和周四的腾讯了&nbsp;&nbsp;加油!!!
解zj:大三的第一段面试居然是这样的结局
查看15道真题和解析
点赞 评论 收藏
分享
评论
4
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务