栈和队列之用2个栈实现一个队列

举报
chenyu 发表于 2021/07/27 01:53:48 2021/07/27
【摘要】 import java.util.Stack; /** * @author chenyu * 题目:编写一个类,用2个栈实现一个队列,支持队列的基本操作(add poll peek) * 思路:栈的特点是先进后出,而队列是先进先出,我们用两个栈真好把顺序反过来实现类似队列的操作,如下,将1-5依次压入stackPush, * 再讲5-1倒入stackPop,从stackPop...

  
  1. import java.util.Stack;
  2. /**
  3. * @author chenyu
  4. * 题目:编写一个类,用2个栈实现一个队列,支持队列的基本操作(add poll peek)
  5. * 思路:栈的特点是先进后出,而队列是先进先出,我们用两个栈真好把顺序反过来实现类似队列的操作,如下,将1-5依次压入stackPush,
  6. * 再讲5-1倒入stackPop,从stackPop弹出时,顺序就像队列一样
  7. * 5 1
  8. * 4 2
  9. * 3 3
  10. * 2 4
  11. * 1 5
  12. * stackPush stackPop
  13. * 必须做到下面2点
  14. * 1、如果stackPush往stackPop里面压入数据,那么必须一次性把stackPush中的数据全部压入
  15. * 2、如果stackPop不为空,stackPush绝对不能向stackPop中压入数据
  16. */
  17. public class TwoStacksQueue {
  18. public Stack<Integer> stackPush;
  19. public Stack<Integer> stackPop;
  20. public TwoStacksQueue(){
  21. stackPush=new Stack<Integer>();
  22. stackPop=new Stack<Integer>();
  23. }
  24. public void add(int value){
  25. stackPush.push(value);
  26. }
  27. public int poll(){
  28. if(s

文章来源: chenyu.blog.csdn.net,作者:chen.yu,版权归原作者所有,如需转载,请联系作者。

原文链接:chenyu.blog.csdn.net/article/details/49983337

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。