栈和队列之仅用递归函数和栈操作逆序一个栈

举报
chenyu 发表于 2021/07/27 01:17:02 2021/07/27
【摘要】 import java.util.Stack; /** * recursion 递归的意思 * @author chenyu * 题目:仅用递归函数和栈操作逆序一个栈,列如一次压入1、2、3、4、5 栈顶到栈底是5、4、3、2、1 * 将这个栈转置后栈顶到栈底依次为1、2、3、4、5 * * 思路:需要两递归函数 * 第一个递归函数是去除栈底并且得到栈底的函数 * 第二个...

  
  1. import java.util.Stack;
  2. /**
  3. * recursion 递归的意思
  4. * @author chenyu
  5. * 题目:仅用递归函数和栈操作逆序一个栈,列如一次压入1、2、3、4、5 栈顶到栈底是5、4、3、2、1
  6. * 将这个栈转置后栈顶到栈底依次为1、2、3、4、5
  7. *
  8. * 思路:需要两递归函数
  9. * 第一个递归函数是去除栈底并且得到栈底的函数
  10. * 第二个递归函数是依次调用第一个递归函数,然后再压入栈
  11. */
  12. public class ReverseStackByRecursion {
  13. public static void main(String[] args) {
  14. Stack<Integer> stack=new Stack<Integer>();
  15. stack.push(1);
  16. stack.push(2);
  17. stack.push(3);
  18. stack.push(4);
  19. stack.push(5);
  20. reverse(stack);
  21. while(!stack.empty()){
  22. System.out.println(stack.pop());
  23. }
  24. }
  25. /**
  26. * 去除栈底并且得到栈底的函数
  27. * @param stack
  28. * @return
  29. */
  30. public static int getAndRemoveLastElement(Stack<Integer> stack){
  31. int result =stack.pop();
  32. if(stack.isEmpty()){
  33. return result;
  34. }else{
  35. int last=getAndRemoveLastElement(stack);
  36. stack.push(res

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

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

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

评论(0

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

全部回复

上滑加载中

设置昵称

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

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

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