用两个栈实现队列与二叉树的镜像
2016-05-28 22:54
204 查看
题目描述
用两个栈来实现一个队列,完成队列的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; } } }
相关文章推荐
- AVL树-自平衡二叉查找树(Java实现)
- C++基于栈实现铁轨问题
- C语言二叉树的非递归遍历实例分析
- C语言栈的表示与实现实例详解
- 使用C语言构建基本的二叉树数据结构
- C语言实现颠倒栈的方法
- 一波二叉树遍历问题的C++解答实例分享
- 举例讲解C语言程序中对二叉树数据结构的各种遍历方式
- C++非递归队列实现二叉树的广度优先遍历
- 算法系列15天速成 第十天 栈
- PHP实现的线索二叉树及二叉树遍历方法详解
- C#使用前序遍历、中序遍历和后序遍历打印二叉树的方法
- 一看就懂:图解C#中的值类型、引用类型、栈、堆、ref、out
- Array栈方法和队列方法的特点说明
- java数据结构之java实现栈
- 浅析栈区和堆区内存分配的区别
- C#非递归先序遍历二叉树实例
- C++将二叉树转为双向链表及判断两个链表是否相交
- C++非递归建立二叉树实例
- C语言实现找出二叉树中某个值的所有路径的方法