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

思路:
1.两个栈,一个栈正常存放数据,另一个栈在每次存数据时,选择最小的数据存入。即和当前数据和栈顶数据比较,哪个小存哪个。

import java.util.Stack;

public class Solution {

     
    Stack<Integer> stack = new Stack<>();
    Stack<Integer> stack2 = new Stack<>();
    public void push(int node) {
         stack.push(node);
         if(stack2.isEmpty()){
             stack2.push(node);
         }else{
             int value = stack2.peek();
             if(node > value){
                 stack2.push(value);
             }else{
                 stack2.push(node);
             }
         }
         
        
    }
    
    public void pop() {
        stack.pop();
        stack2.pop();
    }
    
    public int top() {
        return stack.peek();
    }
    
    public int min() {
        return stack2.peek();
    }
}
全部评论

相关推荐

兄弟们,实习都是在接各种api,该怎么包装简历
仁者伍敌:感觉我自己做小项目也是各种api啊,我要怎么包装简历
点赞 评论 收藏
分享
点赞 评论 收藏
分享
八股刚起步,看了javaguide,小林coding,还有面渣,感觉面渣是体验最好的,请问只看面渣够用吗,有不完善的需要补吗?
码农索隆:先背最基础的知识,然后理解情景题,现在面试大多数喜欢问情景题,更考验面试者的基础和临场发挥情况
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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