题解 | #设计getMin功能的栈#

设计getMin功能的栈

https://www.nowcoder.com/practice/05e57ce2cd8e4a1eae8c3b0a7e9886be

import java.util.*;

// 注意类名必须为 Main, 不要有任何 package xxx 信息
public class Main {
    public static void main(String[] args) {

        //正常保存数字的栈
        Stack<Long> stackNum = new Stack<>();
        //保存最小值的栈
        Stack<Long> stackMIn = new Stack<>();

        Scanner in = new Scanner(System.in);

        int N = in.nextInt();

        for (int i = 0; i < N; i++) {
            String str = in.next();

            if (str.startsWith("push")) {
                long num = in.nextInt();
                stackNum.push(num);
                //最小栈入栈的时机
                if (stackMIn.isEmpty() || num <= stackMIn.peek()) {
                    stackMIn.push(num);
                }
            } else if (str.startsWith("pop")) {
                long popNum = stackNum.pop();
                //最小栈弹出的时机
                if (popNum == stackMIn.peek()) {
                    stackMIn.pop();
                }
            } else if (str.startsWith("getMin")) {
                System.out.println(stackMIn.peek());
            }
        }

    }
}

栈和队列,记录栈和队列的一些题

全部评论

相关推荐

Twilight_m...:经典我朋友XXXX起手,这是那种经典的不知道目前行情搁那儿胡编乱造瞎指导的中年人,不用理这种**
点赞 评论 收藏
分享
05-12 11:09
已编辑
门头沟学院 后端
已注销:没必要放这么多专业技能的描述。这些应该是默认已会的,写这么多行感觉在凑内容。项目这块感觉再包装包装吧,换个名字,虽然大家的项目基本都是网上套壳的,但是你这也太明显了。放一个业务项目,再放一个技术项目。技术项目,例如中间件的一些扩展和尝试。
简历中的项目经历要怎么写
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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