二叉树遍历(Java实现)
二叉树遍历(Java实现)
主要是二叉树的遍历,包括递归遍历和非递归遍历
- import java.util.ArrayDeque;
- import java.util.ArrayList;
- import java.util.List;
- import java.util.Queue;
- public class BinaryNode<T> {
- /**
- * 泛型BinaryNode类
- */
- public T item;
- public BinaryNode<T> left,right;//左右子树
- public BinaryNode(T item)
- {
- this.item = item;
- left = right = null;
- }
- public BinaryNode (T item, BinaryNode<T> left, BinaryNode<T> right)
- {
- this.item = item;
- this.left = left;
- this.right = right;
- }
- public T getNodeValue() {
- return item;
- }
- public void setNodeValue(T item) {
- this.item = item;
- }
- public BinaryNode<T> getLeft() {
- return left;
- }
- public void setLeft(BinaryNode<T> left) {
- this.left = left;
- }
- public BinaryNode<T> getRight() {
- return right;
- }
- public void setRight(BinaryNode<T> right) {
- this.right = right;
- }
- //判断是否为叶子
- public boolean isLeaf(){
- return (left==null)&&(right==null);
- }
- //前序遍历二叉树(递归)
- public List<BinaryNode<T>> toStringPreorder(BinaryNode<T> node){
- List<BinaryNode<T>> list=new ArrayList<BinaryNode<T>>();
- list.add(node);
- if (node.left!=null) {
- list.addAll(toStringPreorder(node.left));
- }
- if (node.right!=null) {
- list.addAll(toStringPreorder(node.right));
- }
- return list;
- }
- //前序遍历二叉树(非递归)
- public List<BinaryNode<T>> toStringPreorderNoRec(BinaryNode<T> node){
- List<BinaryNode<T>> list=new ArrayList<BinaryNode<T>>();
- ArrayDeque<BinaryNode<T>> stack=new ArrayDeque<BinaryNode<T>>();
- while ((node!=null)||!stack.isEmpty()) {
- if (node!=null) {
- list.add(node);
- stack.push(node);
- node=node.left;
- } else {
- node=stack.peek();
- stack.pop();
- node=node.right;
- }
- }
- return list;
- }
- //中序遍历二叉树
- public List<BinaryNode<T>> toStringInorder(BinaryNode<T> node){
- List<BinaryNode<T>> list=new ArrayList<BinaryNode<T>>();
- if (node.left!=null) {
- list.addAll(toStringPreorder(node.left));
- }
- list.add(node);
- if (node.right!=null) {
- list.addAll(toStringPreorder(node.right));
- }
- return list;
- }
- //中序遍历二叉树(非递归)
- public List<BinaryNode<T>> toStringInorderNoRec(BinaryNode<T> node){
- List<BinaryNode<T>> list=new ArrayList<BinaryNode<T>>();
- ArrayDeque<BinaryNode<T>> stack=new ArrayDeque<BinaryNode<T>>();
- while ((node!=null)||!stack.isEmpty()) {
- if (node!=null) {
- stack.push(node);
- node=node.left;
- } else {
- node=stack.peek();
- list.add(node);
- stack.pop();
- node=node.right;
- }
- }
- return list;
- }
- //后序遍历二叉树
- public String toStringPostorder(){
- String result="";
- if (left!=null) {
- result += left.toStringPostorder();
- }
- if (right!=null) {
- result += right.toStringPostorder();
- }
- result += item;
- return result;
- }
- //后序遍历二叉树(非递归)
- /**
- * 先遍历树的逆后序遍历(根、右、左),在翻转逆后序遍历就是后序遍历二叉树(左、右、根)
- * @return result栈
- */
- public ArrayDeque<BinaryNode<T>> toStringPostorderNoRec(BinaryNode<T> node){
- ArrayDeque<BinaryNode<T>> stack=new ArrayDeque<BinaryNode<T>>();
- ArrayDeque<BinaryNode<T>> result=new ArrayDeque<BinaryNode<T>>();
- while ((node!=null)||!stack.isEmpty()) {
- if (node!=null) {
- result.push(node);
- stack.push(node);
- node=node.right;
- } else {
- node=stack.peek();
- stack.pop();
- node=node.left;
- }
- }
- return result;
- }
- //后序遍历二叉树2(非递归)
- /**
- * 要保证根结点在左孩子和右孩子访问之后才能访问,因此对于任一结点P,先将其入栈。如果P不存在左孩子和右孩子,则可以直接访问它;
- * 或者P存在左孩子或者右孩子,但是其左孩子和右孩子都已被访问过了,则同样可以直接访问该结点。若非上述两种情况,
- * 则将P的右孩子和左孩子依次入栈,这样就保证了每次取栈顶元素的时候,左孩子在右孩子前面被访问,左孩子和右孩子都在根结点前面被访问。
- * @return result栈
- */
- public ArrayList<BinaryNode<T>> toStringPostorderNoRec2(BinaryNode<T> root){
- ArrayDeque<BinaryNode<T>> stack=new ArrayDeque<BinaryNode<T>>();
- ArrayList<BinaryNode<T>> result=new ArrayList<BinaryNode<T>>();
- BinaryNode<T> curr;//当前栈顶指针
- BinaryNode<T> pre=null;//前一次访问节点
- stack.push(root);
- while (!stack.isEmpty()) {
- curr=stack.peek();
- if ((curr.left==null&&curr.right==null)||(pre!=null&&(pre==curr.left||pre==curr.right))) {
- result.add(curr);//输出结果
- stack.pop();
- pre=curr;
- } else {
- if (curr.right!=null) {
- stack.push(curr.right);
- }
- if (curr.left!=null) {
- stack.push(curr.left);
- }
- }
- }
- return result;
- }
- //层序遍历(广度优先遍历)
- public List<BinaryNode<T>> toStringLevelOrder(){
- List<BinaryNode<T>> list=new ArrayList<BinaryNode<T>>();
- Queue<BinaryNode<T>> queue=new ArrayDeque<BinaryNode<T>>();
- queue.offer(this);//root
- while (!(queue.isEmpty())) {
- list.add(queue.peek());
- BinaryNode<T> node=queue.poll();
- if (node.left != null) {
- queue.offer(node.left);
- }
- if (node.right != null) {
- queue.offer(node.right);
- }
- }
- return list;
- }
- }
二叉树遍历(Java实现)的更多相关文章
- 二叉树遍历-JAVA实现
二叉树遍历分为前序.中序.后序递归和非递归遍历.还有层序遍历. //二叉树节点 public class BinaryTreeNode { private int data; private Bina ...
- 二叉树遍历Java实现
[仅贴代码及测试结果] -------------------BinaryTree.java------------------------------ class Tree<E>{ E ...
- 数据结构二叉树的java实现,包括二叉树的创建、搜索、删除和遍历
根据自己的学习体会并参考了一些网上的资料,以java写出了二叉树的创建.搜索.删除和遍历等操作,尚未实现的功能有:根据先序和中序遍历,得到后序遍历以及根据后序和中序遍历,得到先序遍历,以及获取栈的深度 ...
- 二叉树 Java 实现 前序遍历 中序遍历 后序遍历 层级遍历 获取叶节点 宽度 ,高度,队列实现二叉树遍历 求二叉树的最大距离
数据结构中一直对二叉树不是很了解,今天趁着这个时间整理一下 许多实际问题抽象出来的数据结构往往是二叉树的形式,即使是一般的树也能简单地转换为二叉树,而且二叉树的存储结构及其算法都较为简单,因此二叉树显 ...
- java 二叉树遍历
package com.lever; import java.util.LinkedList;import java.util.Queue; /** * 二叉树遍历 * @author lckxxy ...
- java数据结构之二叉树遍历的非递归实现
算法概述递归算法简洁明了.可读性好,但与非递归算法相比要消耗更多的时间和存储空间.为提高效率,我们可采用一种非递归的二叉树遍历算法.非递归的实现要借助栈来实现,因为堆栈的先进后出的结构和递归很相似.对 ...
- 【数据结构】之二叉树的java实现
转自:http://blog.csdn.net/wuwenxiang91322/article/details/12231657 二叉树的定义: 二叉树是树形结构的一个重要类型.许多实际问题抽象出来的 ...
- 二分法与二叉树的 Java 实现
算法与数据结构始终是计算机基础的重要一环,今天我们来讨论下 Java 中二叉树的实现以及一些简单的小算法,如二分查找,归并排序等. 二分查找 二分查找是一种在有序数组中查找某一特定元素的搜索算法,它在 ...
- 二叉树的Java实现及特点总结
二叉树是一种非常重要的数据结构,它同时具有数组和链表各自的特点:它可以像数组一样快速查找,也可以像链表一样快速添加.但是他也有自己的缺点:删除操作复杂. 我们先介绍一些关于二叉树的概念名词. 二叉树: ...
随机推荐
- vuejs 实现富文本
<div v-html="ritchtext" style="font-size:32px;" v-if="!platform" &g ...
- 【迷你微信】基于MINA、Hibernate、Spring、Protobuf的即时聊天系统:8.自定义传输协议
欢迎阅读我的开源项目<迷你微信>服务器)与<迷你微信>客户端 前言 在上一篇中,我们讲到了<迷你微信>服务器)的主体架构,还讲到了如何在现有功能上进行拓展,但是拓展 ...
- vs移动团队项目集合
vs移动团队项目集合: https://msdn.microsoft.com/zh-cn/library/vs/alm/dd936138(v=vs.120)/css
- windows10下git报错warning: LF will be replaced by CRLF in readme.txt. The file will have its original line endings in your working directory.
window10下使用git时 报错如下: $ git add readme.txtwarning: LF will be replaced by CRLF in readme.txt.The fil ...
- HDU 2191 悼念汶川地震(多重背包)
思路: 多重背包转成01背包,怎么转?把一种大米看成一堆单个的物品,每件物品要么装入,要么不装.复杂度比01背包要大.时间复杂度为O(vns)(这里S是所有物品的数量s之和).这个做法太粗糙了,但就是 ...
- 500 Days Of Summer
<和莎莫的500天>,一部爱情片. Summer和Tom两人不同的爱情观走在了一起,或许真的就是爱情观不同,或许是Summer爱Tom爱的不够深,最终的结局是那么不尽人意. 有人愿意把秘密 ...
- java Vamei快速教程15 IO基础
作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! 计算机最重要的功能是处理数据.一个有用的计算机语言需要拥有良好的IO功能,以便让未 ...
- Producer & Consumer
需要与Eureka结合使用 Eureka环境搭建 Producer 一.pom文件 <?xml version="1.0" encoding="UTF-8" ...
- [Rodbourn's Blog]How to export Excel plots to a vector image (EPS, EMF, SVG, etc.)
This is a bit of a workaround, but it's the only way I know of to export an Excel plot into a vector ...
- codeforces 600D Area of Two Circles' Intersection
分相离,内含,想交三种情况讨论一下. 主要是精度和数据范围的问题,首先数据用long double,能用整型判断就不要用浮点型. 题目中所给的坐标,半径是整型的,出现卡浮点判断的情况还是比较少的. 最 ...