用两个栈实现队列与二叉树的镜像
来源:互联网 发布:sql2000数据库安装 编辑:程序博客网 时间:2024/06/06 01:43
题目描述
用两个栈来实现一个队列,完成队列的Push和Pop操作。 队列中的元素为int类型。
思路:队列:是先进先出;栈:是先进后出。由此可见,用两个栈可以实现队列。首先队列push的时候,就只需要把元素放进栈1,这里需要注意的是int与integer的转换,即new Integer(int) 。队列pop的时候,就是把栈1里面的元素放到栈2中,然后将栈2中的元素pop就可以实现了。这里又涉及到将Integer的类型转为int类型的方法Integer.intValue();
public class Solution { Stack<Integer> stack1 = new Stack<Integer>(); Stack<Integer> stack2 = new Stack<Integer>(); public void push(int node) { stack1.push(new Integer(node)); } public int pop() { if(stack2.isEmpty()){ while(!stack1.isEmpty()){ stack2.push(stack1.pop()); } } return stack2.pop().intValue(); }}
题目描述
操作给定的二叉树,将其变换为源二叉树的镜像。
输入描述:
二叉树的镜像定义:源二叉树
8 / \ 6 10 / \ / \ 5 7 9 11 镜像二叉树 8 / \ 10 6 / \ / \ 11 9 7 5
思路:由题目的意思可知,就是将所有的左右子节点相互交换。我们也不知道到底有多少个左右子节点,所以可以采用递归的方法。这里要注意的是定义一个中间变量的类型是 TreeNode,自己因为看到上面的案例图,开始写的是int。
public class Solution { public void Mirror(TreeNode root) { if(root != null){ Mirror(root.left); Mirror(root.right); TreeNode temp = root.left; root.left=root.right; root.right=temp; } }}
0 0
- 用两个栈实现队列与二叉树的镜像
- 栈与队列的实现__ 两个栈实现队列 vs 两个队列实现栈
- 栈与队列的实现__ 两个栈实现队列 vs 两个队列实现栈
- 二叉树的镜像java实现
- 用循环的方法实现二叉树的镜像
- 两个栈实现队列与两个队列实现栈
- 两个栈实现队列与两个队列实现栈
- 两个栈实现队列与两个队列实现栈
- 数据结构与算法分析笔记与总结(java实现)--二叉树12:二叉树的镜像
- 笔试面试算法经典--二叉树的镜像-递归与非递归实现(Java)
- 栈,队列和二叉树的实现
- 用两个栈实现队列的源代码
- 用两个栈实现队列的功能
- 用两个栈实现队列的过程
- 用两个栈实现队列的操作
- 用两个栈实现队列的操作
- 用两个栈实现的队列
- 用两个栈实现队列与用两个队列实现栈
- vim、gcc/g++、ctags简析
- 低功耗蓝牙(BLE)
- PHP算法——冒泡排序
- Theano下怎么配置GPU和cudnn加速
- NJSD2016《 高效率的Android开发》PPT分享
- 用两个栈实现队列与二叉树的镜像
- Leetcode no. 231
- python初学(3)列表(List)应用(待续ing)
- assert和if使用的环境及使用场景
- 【LQ系列】BEGIN-1~BEGIN-4
- jmx实例
- android stdio 设置屏幕旋转后保存数据
- 关于JAVA的那些事儿
- 20—小结(Week)