二叉树的遍历(traversing binary tree)是指从根节点出发,按照某种次序依次访问二叉树中所有节点,使得每个节点仅被访问一次

前序遍历:若二叉树为空,则空操作返回null。否则先访问根节点,然后前序遍历左子树,再前序遍历右子树

中序遍历:若二叉树为空,则空操作返回null。否则从根节点开始,中序遍历根节点左子树,然后访问根节点,最后中序遍历右子树

后序遍历:若二叉树为空,则空操作返回null。否则以从左到右先叶子后节点的方式遍历访问左右子树,最后访问根节点

层序遍历:若树为空,空操作返回null。否则从树的第一层,也就是根节点开始访问,从上而下逐层遍历,在同一层中,从左到右对结点逐个访问

com

└── rust

└── datastruct

├── BinaryTree.java

└── TestBinaryTree.java

二叉树用一个类来实现,并包含内部类节点

以下是Java代码:

 package com.rust.datastruct;

 public class BinaryTree {
     private int BinaryNodeCount = 0;
     BinaryNode root;
     public BinaryTree(){}

     public BinaryNode createRoot(){
         return createRoot(1,null);
     }
     public BinaryNode createRoot(int key,String data){
         BinaryNode root = new BinaryNode(key, data);
         this.root = root;
         return root;
     }

     public BinaryNode createNode(int key,String data){
         return new BinaryNode(key,data);
     }
     public int getNodeCount(){
         return BinaryNodeCount;
     }
     public BinaryNode getRoot(){
         return root;
     }
     public void visitNode(BinaryNode node){
         if (node == null) {
             return ;
         }
         node.setVisited(true);
         System.out.print(node.getData());
     }
     // 前序遍历
     public void preOrderTravels(BinaryNode node) {
         if (node == null) {
             return;
         } else {
             BinaryNodeCount++;
             visitNode(node);
             preOrderTravels(node.leftChild);
             preOrderTravels(node.rightChild);
         }
     }
     // 中序遍历
     public void midOrderTravels(BinaryNode node) {
         if (node == null) {
             return;
         } else {
             BinaryNodeCount++;
             midOrderTravels(node.leftChild);
             visitNode(node);
             midOrderTravels(node.rightChild);
         }
     }
     // 后序遍历
     public void postOrderTravels(BinaryNode node) {
         if (node == null) {
             return;
         } else {
             BinaryNodeCount++;
             postOrderTravels(node.leftChild);
             postOrderTravels(node.rightChild);
             visitNode(node);
         }
     }  

     class BinaryNode{
         private int key;
         private String data;
         private BinaryNode leftChild = null;
         private BinaryNode rightChild = null;
         private boolean isVisited = false;

         public int getKey() {
             return key;
         }
         public void setKey(int key) {
             this.key = key;
         }
         public String getData() {
             return data;
         }
         public void setData(String data) {
             this.data = data;
         }
         public BinaryNode getLeftChild() {
             return leftChild;
         }
         public void setLeftChild(BinaryNode leftChild) {
             this.leftChild = leftChild;
         }
         public BinaryNode getRightChild() {
             return rightChild;
         }
         public void setRightChild(BinaryNode rightChild) {
             this.rightChild = rightChild;
         }
         public boolean isVisited() {
             return isVisited;
         }
         public void setVisited(boolean isVisited) {
             this.isVisited = isVisited;
         }
         public BinaryNode(){

         }
         public BinaryNode(int key, String data){
             this.key = key;
             this.data = data;
             this.leftChild = null;
             this.rightChild = null;
         }
     }

 }

里面内置前序遍历、中序遍历和后序遍历三种方法

 package com.rust.datastruct;

 import com.rust.datastruct.BinaryTree.BinaryNode;

 public class TestBinaryTree {

     public static void main(String args[]){
         BinaryTree bt = new BinaryTree();
         initTree(bt, 1, "A");
         System.out.println("********preOrderTravels********");
         bt.preOrderTravels(bt.root);
         System.out.println();
         System.out.println("********midOrderTravels********");
         bt.midOrderTravels(bt.root);
         System.out.println();
         System.out.println("********postOrderTravels********");
         bt.postOrderTravels(bt.root);
     }
     /**
      *               A
      *        B            C
      *    D     E      F     G
      * H   I  J
      * @param bt 输入一个二叉树对象,定义一个根结点
      * @param rootKey
      * @param rootData
      */
     public static void initTree(BinaryTree bt,int rootKey, String rootData){
         BinaryNode root = bt.createRoot(rootKey, rootData);
         BinaryNode nodeB = bt.createNode(2, "B");
         BinaryNode nodeC = bt.createNode(3, "C");
         BinaryNode nodeD = bt.createNode(4, "D");
         BinaryNode nodeE = bt.createNode(5, "E");
         BinaryNode nodeF = bt.createNode(6, "F");
         BinaryNode nodeG = bt.createNode(7, "G");
         BinaryNode nodeH = bt.createNode(8, "H");
         BinaryNode nodeI = bt.createNode(9, "I");
         BinaryNode nodeJ = bt.createNode(10, "J");
         root.setLeftChild(nodeB);
         root.setRightChild(nodeC);
         nodeB.setLeftChild(nodeD);
         nodeB.setRightChild(nodeE);
         nodeC.setLeftChild(nodeF);
         nodeC.setRightChild(nodeG);
         nodeD.setLeftChild(nodeH);
         nodeD.setRightChild(nodeI);
         nodeE.setRightChild(nodeJ);
     }
 }

输出:

********preOrderTravels********

ABDHIEJCFG

********midOrderTravels********

HDIBEJAFCG

********postOrderTravels********

HIDJEBFGCA

·树,森林和二叉树

#树转换为二叉树

1.加线,在所有兄弟节点之间加一条线

2.去线,对树中每一个节点,只保留它与第一个孩子结点的连线,删除它与其它孩子节点之间的连线

3.层次调整。以树的根节点为轴心,将整棵树顺时针旋转一定的角度,使其结构分明

#森林转换为二叉树

1.把每棵树转换为二叉树

2.第一棵二叉树不动,从第二棵二叉树开始,依次把后一棵二叉树的根节点作为前一棵二叉树的根节点的右孩子,

用线连起来。当所有的二叉树连接起来后就得到了由森林转换来的二叉树。

#二叉树转换为树

右孩子都跨一层连接上去,删掉二叉树右孩子的连线

#二叉树转换为森林

逐层删掉右孩子的连线

二叉树 - 建立与遍历使用Java的更多相关文章

  1. 二叉树建立,遍历和二叉排序树的判断【c++】

    // test.cpp : Defines the entry point for the console application. // #include "stdafx.h" ...

  2. 二叉树的层次遍历(Java代码实现)

    与树的前中后序遍历的DFS思想不同,层次遍历用到的是BFS思想.一般DFS用递归去实现(也可以用栈实现),BFS需要用队列去实现. 层次遍历的步骤是: 1.对于不为空的结点,先把该结点加入到队列中 2 ...

  3. 二叉树建立及遍历 C++ 源码

    #define _CRT_SECURE_NO_WARNINGS #include<iostream> #include <stdlib.h> using namespace s ...

  4. 数据结构二叉树的递归与非递归遍历之java,javascript,php实现可编译(1)java

    前一段时间,学习数据结构的各种算法,概念不难理解,只是被C++的指针给弄的犯糊涂,于是用java,web,javascript,分别去实现数据结构的各种算法. 二叉树的遍历,本分享只是以二叉树中的先序 ...

  5. Java实现二叉树及相关遍历方式

    Java实现二叉树及相关遍历方式 在计算机科学中.二叉树是每一个节点最多有两个子树的树结构.通常子树被称作"左子树"(left subtree)和"右子树"(r ...

  6. 数据结构代码整理(线性表,栈,队列,串,二叉树,图的建立和遍历stl,最小生成树prim算法)。。持续更新中。。。

    //归并排序递归方法实现 #include <iostream> #include <cstdio> using namespace std; #define maxn 100 ...

  7. C语言二叉树的建立与遍历

    二叉树的建立和遍历都要用到递归,先暂时保存一下代码,其中主要是理解递归的思想,其它的就都好理解了.这里是三种遍历方式,其实理解一种,其它的几个就都理解了,就是打印出来的顺序不一样而已.建立和遍历的方式 ...

  8. 二叉树3种递归和非递归遍历(Java)

    import java.util.Stack; //二叉树3种递归和非递归遍历(Java) public class Traverse { /******************一二进制树的定义*** ...

  9. 二叉树遍历(Java实现)

    二叉树遍历(Java实现)   主要是二叉树的遍历,包括递归遍历和非递归遍历 import java.util.ArrayDeque; import java.util.ArrayList; impo ...

随机推荐

  1. Java中的系统时间

    System.currentTimeMillis()产生一个当前的毫秒,这个毫秒其实就是自1970年1月1日0时起的毫秒数,Date()其实就是相当于Date(System.currentTimeMi ...

  2. 最新Hadoop Shell完全讲解

    本文为原创博客,转载请注明出处:http://www.cnblogs.com/MrFee/p/4683953.html    1.appendToFile   功能:将一个或多个源文件系统的内容追加至 ...

  3. oracle查询第一篇

    第一个小知识点: clear 在oracle中也可以用以清除屏幕上的内容 第二个小知识点: 在一个表中插入自身的查询结果 insert into my_table (id,name,age) sele ...

  4. ssh隧道

    最近有需求使用ssh隧道,顺便研究了下,以下记录一下大概说明 ssh隧道顾名思义在可以通过ssh连接的server之间建立加密隧道,常用于突破网络限制 常用三种端口转发模式:本地端口转发,远程端口转发 ...

  5. HTML中那些不常用标签

    先思考一个问题:为什么H5里面又多了那么多看似没用的标签? 我们知道,<div>能干百分之99的标签能干的事,而标签的主要作用是用来包裹内容,只要把基本内容都包含进去不就好了??胡闹!不带 ...

  6. rabbitmq 死信邮箱配置(dead-letter)

    DLX,Dead-Letter-Exchange(死信邮箱)利用DLX,当消息在一个队列中变成死信后,它能被重新publish到另一个Exchange,这个Exchange就是DLX.消息变成死信一向 ...

  7. Elasticsearch重要配置

    虽然Elasticsearch需要很少的配置,但是有一些设置需要手动配置,并且必须在进入生产之前进行配置. path.data  and path.logs cluster.name node.nam ...

  8. 【转载】SQL Server行转列,列转行

    行转列,列转行是我们在开发过程中经常碰到的问题.行转列一般通过CASE WHEN 语句来实现,也可以通过 SQL SERVER 2005 新增的运算符PIVOT来实现.用传统的方法,比较好理解.层次清 ...

  9. 在ASP.Net MVC 中如何实现跨越Session的分布式TempData

    Hi,guys!Long time no see! 1.问题的引出 我相信大家在项目中都使用过TempData,TempData是一个字典集合,一般用于两个请求之间临时缓存数据或者页面之间传递消息.也 ...

  10. java 类变量的初始化

    有代码如下:class Price{    final static Price INSTANCE = NEW Price(2.8);    static double initPrice = 20; ...