《CTCI》3.5 用两个栈实现队列

《CTCI》 P142

3 栈与队列

题目

3.5 实现一个MyQueue类,该类用两个栈来实现一个队列。

解答

#include <stack>

template <typename T> class queue
{
public:
    void push(const T& val);
    void pop();
    const T& front();
    const T& back();
    size_t size() const;
    bool empty() const;

private:
    std::stack<T> s1;
    std::stack<T> s2;
};

template <typename T> void queue<T>::push(const T& val)
{
    s1.push(val);
}

template <typename T> void queue<T>::pop()
{
    if (empty())
        return;
    if (s2.empty())
    {
        while (!s1.empty())
        {
            s2.push(s1.top());
            s1.pop();
        }
    }
    s2.pop();
}

template <typename T> const T& queue<T>::front()
{
    if (s2.empty())
    {
        while (!s1.empty())
        {
            s2.push(s1.top());
            s1.pop();
        }
    }

    return s2.top();
}

template <typename T> const T& queue<T>::back()
{
    if (s1.empty())
    {
        while (!s2.empty())
        {
            s1.push(s2.top());
            s2.pop();
        }
    }

    return s1.top()
}

template <typename T> size_t queue<T>::size() const
{
    return s1.size() + s2.size();
}

template <typename T> bool queue<T>::empty() const
{
    return size() == 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值