Problem : Implement a stack with push() , pop() and a min() (which returns the minimum element in the stack). All operations should be O(1).  Another popular question, I've searched around a lot came across many answers, but only one had completeness. It's important to note that with the stack you don't have random access to the contents of the stack when implementing your solution.   The solution I'm describing involves using 2 stacks, one is to store the data elements themselves ( mainstack ) and the other to store minimum values, which i'll refer to as minstack. Now we can have 2 parallel stacks where we push and pop on the minstack along with the mainstack, keeping track of the minimum value of course. But we can optimize this further. We only need to push values on the minimum stack only when you push a value on the main stack that is less than or equal  to the current top element of the minstack.  Here's are the two stacks after pushing 67,44,20,77,99,1...
Programming Puzzles and Challenges.