面试题--用两个栈实现一个队列

本文介绍了一种使用两个栈来模拟队列操作的方法。其中一个栈用于入队操作,另一个栈用于出队操作。当出队栈为空时,将入队栈的所有元素依次弹出并压入出队栈,从而实现先进先出的队列特性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

class SimulateQueueBy2Stacks
    {
        private Stack<int> _stack1 = new Stack<int>();
        private Stack<int> _stack2 = new Stack<int>();

        public void Enqueue(int value)
        {
            _stack1.Push(value);
        }

        public int Dequeue()
        {
            if(Empty())
                throw new Exception("队列空");
            else
            {
                if (_stack2.Count == 0)
                {
                    while (_stack1.Count != 0)
                    {
                        _stack2.Push(_stack1.Pop());
                    }
                }
                return _stack2.Pop();
            }           
        }

        public bool Empty()
        {
            return _stack1.Count == 0 && _stack2.Count == 0;
        }
    }
一个栈用来进,一个栈用来出。需要满足,用来出的栈必须全部出栈才能有新值入栈,用来进的栈必须全部出栈才能有新值入栈
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值