import java.util.*;
import java.util.Stack;

public class Solution {
    HashMap<Integer, Integer> map;
    Stack<Integer> stack;
    Stack<Integer> stack2;
    int minValue;
    public Solution() {
        this.map = new HashMap<>();
        this.stack = new Stack<>();
        this.stack2 = new Stack<>();
        this.minValue = Integer.MAX_VALUE;
    }

    public void push(int node) {
        stack.push(node);
        if (stack2.isEmpty() || node <= stack2.peek()) {
            stack2.push(node);
        } else {
            stack2.push(stack2.peek());
        }
    }

    public void pop() {
        stack.pop();
        stack2.pop();
    }

    public int top() {
        return stack.peek();
    }

    public int min() {
        return stack2.peek();
    }
}