面试题21:包含min函数的栈

题目:定义栈的数据结构,请在该类型中实现一个能够得到栈的最小元素的min函数。在该栈中,调用min,push及pop函数的时间复杂度都是O(1)。


分析

栈应该是我们很熟悉的一种数据结构了,它是一种“后进先出”的数据结构,并且只能在栈的一端(栈顶)进行操作。所以其push和pop操作的时间复杂度都是O(1)。如果题目没有要求min函数的时间复杂度的话,我们可以在min函数里面遍历所有的元素并将其保存起来,找到最小的元素后再将所有元素以相反的顺序放回去。但现在这种方案显然不行。

我们可以定义两个栈,一个存放我们需要的元素,称为元素栈。另一个存放当前元素栈里面最小的一个元素值,称为最小值栈。这样,当调用min函数时,直接返回最小值栈的栈顶就可以了,达到了O(1)的时间复杂度。这是一个“以空间换时间”的方法。

这样,在插入元素时,先将其插入元素栈里,并判断该元素是否小于最小值栈的栈顶元素,若小于,则将该元素插入最小值栈,否则,将最小值栈的栈顶元素在此插入最小值栈。pop时,两个都pop即可。

代码如下:

class StackIsEmpty{};

template<typename T>
class MyStack{
public:
    void push(const T& t)
    {
        if(s.empty())
        {
            m.push(t);
        }
        else
        {
            if(t<m.top())
            {
                m.push(t);
            }
            else
            {
                m.push(m.top());
            }
        }
        s.push(t);
    }
    void pop()
    {
        if(!s.empty())
        {
            s.pop();
            m.pop();
        }
        else
            throw StackIsEmpty();
    }
    T& min()
    {
        if(!s.empty())
        {
            return m.top();
        }
        else
            throw StackIsEmpty();
    }
    bool empty()
    {
        return s.empty();
    }
private:
    stack<T> s;
    stack<T> m;//min
};

以上

如果你有任何想法或是可以改进的地方,欢迎和我交流!

完整代码及测试用例在github上:点我前往





  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值