栈和队列练习之由两个栈组成的队列(尉)

题目

编写一个类,用两个栈实现队列,支持队列的基本操作:add,poll,peek.

思路

栈的特点是先进后出,那么设有两个栈,第一个栈命名为stackPush,第二个栈命名为stackPop。假设有1,2,3,4,5依次进栈stackPush,然后1-5全部出栈到stackPop,此时stackPop的栈顶元素就是1了,此时出栈的第一个元素就是当前栈顶1了,也就是符合队列的先进先出特性了。在这里插入图片描述
乍一看好像很简单的样子其实不然
在这里插入图片描述

第一种情况StackPush的元素未完全倒入StackPop,会导致本该在队列中部的元素先出队列
第二种情况StackPop不未空时就向stackPop内导入元素则打乱了整个队列的连续性,使得本该在队尾的一段元素与本该在队前的元素颠倒。
如何规避呢?请看代码实现

public class queuebystack {
	private Stack<Integer> stackPush;
	private Stack<Integer> stackPop;

	public queuebystack() {

		this.stackPush = new Stack<Integer>();
		this.stackPop = new Stack<Integer>();
	}

	public void pushToPop() {
		if (stackPop.empty()) {// 只有为空时才倒入
			while (!stackPush.empty()) {
				stackPop.push(stackPush.pop());
			}
		}
	}

	public void add(int queueIn) {
		stackPush.push(queueIn);
		pushToPop();// 只有stackPop为空时,才会向其导入,保存队列连贯性
	}

	public int poll() {
		if (stackPush.empty() && stackPop.empty()) {
			throw new RuntimeErrorException(null, "队列为空!");
		}
		pushToPop();// 如果还没有像stackPop中倒入;
		return stackPop.pop();

	}

	public int peek() {
		if (stackPush.empty() && stackPop.empty()) {
			throw new RuntimeErrorException(null, "队列为空!");
		}
		pushToPop();// 如果还没有像stackPop中倒入;
		return stackPop.peek();

	}
}

图解模拟
在这里插入图片描述
在poll和过程中都会调用pushToPop这个函数,这个函数会判断stackPop是否为空,为空是才表明现阶段符合队列顺序的元素都已出队,不为空时,用stackPush保存下来,直到stackPop为空才一次性导入stackPop。

总结

我想这道题应该主要培养的还是程序员缜密的思维吧,要尽可能考虑到所有可能出现的情况。

结语

谢谢观看
你点的每一个赞,我都会当成喜欢
你评的每一个字,我都会认真对待

在这里插入图片描述

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值