3.如何仅用递归函数和栈操作逆序一个栈
来源:互联网 发布:动漫网站源码整套 编辑:程序博客网 时间:2024/05/29 17:52
题目:实现一个栈中的元素的逆序,只能用递归来实现,不能使用其他数据结构
思路:我对递归不是很熟悉,看了书上的代码,了解了其中的意思后敲了一份,主要是要递归取出该栈中的每一个元素,然后将元素再压栈。所以有两个函数,一个就是取出栈底元素,另一个就是压栈操作,(其实如果直接pop就不用递归了,我觉得这题的意义不大,只是单纯考察递归的使用,因为不用递归更方便操作)
import java.util.Stack;public class ReverseStackByrecursion {public int getBottomElement(Stack<Integer> stack){int tmp = stack.pop();if(stack.isEmpty())return tmp;else{int last = getBottomElement(stack);stack.push(tmp);return last;}}public void reverse(Stack<Integer> stack){if(stack.isEmpty())return;int e = getBottomElement(stack);reverse(stack);stack.push(e);}}
0 0
- 3.如何仅用递归函数和栈操作逆序一个栈
- 仅用递归函数和栈操作逆序一个栈
- 仅用递归函数和栈操作逆序一个栈
- 仅用递归函数和栈操作逆序一个栈
- 栈和队列(3)--如何仅用递归函数和栈操作逆序一个栈
- 栈和队列——如何仅用递归函数和栈操作逆序一个栈
- 栈和队列 如何仅用递归函数和栈操作逆序一个栈
- 栈和队列---如何仅用递归函数和栈操作逆序一个栈
- 如何仅用递归函数和栈操作逆序一个栈
- 数据结构 如何仅用递归函数和栈操作逆序一个栈
- 如何仅用递归函数和栈操作逆序一个栈
- 如何仅用递归函数和栈操作逆序一个栈
- 如何仅用递归函数和栈操作逆序一个栈
- day 1.1如何仅用递归函数和栈操作逆序一个栈
- 程序员面试指南之如何仅用递归函数和栈操作逆序一个栈
- 如何仅用递归函数和栈操作逆序一个栈
- 如何仅用递归函数和栈操作逆序一个栈
- 如何仅用递归函数和栈操作逆序一个栈
- Linux下的I/O
- Spring DI 注解
- 用shape画虚线
- 《Web前端工程师修炼之道》学习笔记
- hive,spark的远程调试设置
- 3.如何仅用递归函数和栈操作逆序一个栈
- 安卓控件使用系列29:TabHost卡片的使用方法2不继承TabActivity、TabHost控件、一个布局文件
- Git部分命令
- java线程池学习(三) —— ThreadPoolExecutor
- 【C++】c++String类浅拷贝、深拷贝
- 【软考】——排序
- android的显示意图和隐示意图
- 安卓四大组件之Activity篇-----开篇
- 对于测试我们需要知道啥?