template<typename T>
class StackWithMin
{
public:
void push(const T& value)
{
m_data.push(value);
if(m_min.size()==0||m_min.top()<value)
m_min.push(value);
else
m_min.push(m_min.top());
}
void pop()
{
if(m_data.size()>0 && m_min.size()>0)
{
m_data.pop();
m_min.pop();
}
}
const T& min()const
{
assert(m_data.size()>0&&m_min.size()>0);
return m_min.top();
}
private:
stack<T> m_data;
stack<T> m_min;
};