Wednesday, July 18, 2012

The stack that could give minimum in O(1)

This is one of my favorite interview question-
You have to create a stack which gives the smallest element in constant (or O(1)) time. 
You can be asked for the largest element instead of smallest also.

Take some time to think. Or read the grayed hint below, followed by the solution and explanation-
You can use linear amount of (extra) memory.
    Ok now the solution. You take a separate stack, call it min-stack. The other stack is the main-stack

    When you push a element in main-stack, compare the new element with top (using peek, not pop) of min-stack. Following cases are possible-
    1. The min-stack is empty => simply push the new element in min-stack as well.
    2. The min-stack top is smaller => do nothing.
    3. The min-stack top is larger => push the new element in min-stack as well.
    4. The min-stack top is equal => push the new element in min-stack as well. 
    When you pop the element from the main-stack, again compare the popped element with the min-stack top. There are only 2 cases now-

    1. The min-stack top is equal => pop from min-stack as well.
    2. The min-stack top is not equal => do nothing
    When the time comes for get minimum, just return the top of min-stack (taking care of underflow).

    For completeness, here is the C++ code

    void stack::push(int a)
    {
    main_stack.push(a);

    if (min_stack.is_empty())
    min_stack.push(a);
    else if (a <= min_stack.top())
    min_stack.push(a);
    }

    int stack::pop()
    {
    //take care of underflow here

    int e = main_stack.top();
    if (min_stack.top() == e)
    min_stack.pop();

    return e;
    }

    int stack::minimum()
    {
    //take care of underflow here

    return min_stack.top();
    }

    No comments:

    Post a Comment