二叉树 - 建立与遍历使用Java
二叉树的遍历(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的更多相关文章
- 二叉树建立,遍历和二叉排序树的判断【c++】
// test.cpp : Defines the entry point for the console application. // #include "stdafx.h" ...
- 二叉树的层次遍历(Java代码实现)
与树的前中后序遍历的DFS思想不同,层次遍历用到的是BFS思想.一般DFS用递归去实现(也可以用栈实现),BFS需要用队列去实现. 层次遍历的步骤是: 1.对于不为空的结点,先把该结点加入到队列中 2 ...
- 二叉树建立及遍历 C++ 源码
#define _CRT_SECURE_NO_WARNINGS #include<iostream> #include <stdlib.h> using namespace s ...
- 数据结构二叉树的递归与非递归遍历之java,javascript,php实现可编译(1)java
前一段时间,学习数据结构的各种算法,概念不难理解,只是被C++的指针给弄的犯糊涂,于是用java,web,javascript,分别去实现数据结构的各种算法. 二叉树的遍历,本分享只是以二叉树中的先序 ...
- Java实现二叉树及相关遍历方式
Java实现二叉树及相关遍历方式 在计算机科学中.二叉树是每一个节点最多有两个子树的树结构.通常子树被称作"左子树"(left subtree)和"右子树"(r ...
- 数据结构代码整理(线性表,栈,队列,串,二叉树,图的建立和遍历stl,最小生成树prim算法)。。持续更新中。。。
//归并排序递归方法实现 #include <iostream> #include <cstdio> using namespace std; #define maxn 100 ...
- C语言二叉树的建立与遍历
二叉树的建立和遍历都要用到递归,先暂时保存一下代码,其中主要是理解递归的思想,其它的就都好理解了.这里是三种遍历方式,其实理解一种,其它的几个就都理解了,就是打印出来的顺序不一样而已.建立和遍历的方式 ...
- 二叉树3种递归和非递归遍历(Java)
import java.util.Stack; //二叉树3种递归和非递归遍历(Java) public class Traverse { /******************一二进制树的定义*** ...
- 二叉树遍历(Java实现)
二叉树遍历(Java实现) 主要是二叉树的遍历,包括递归遍历和非递归遍历 import java.util.ArrayDeque; import java.util.ArrayList; impo ...
随机推荐
- JavaSE教程-03Java中分支语句与四种进制转换
一.分支语句 计算机源于生活,程序模拟现实生活,从而服务生活 行为模式 1,起床,刷牙,洗脸,吃早餐,上课,回家,睡觉(顺序性) 2,如果时间不太够,打个滴滴快车,如果时间够,坐个地铁(选择性) 3, ...
- python基础入门教程《python入门经典》
第一章 在python中使用数字 1.用变量存储信息 1.1变量的类型 变量,用于存储很多不同的数据类型的信息. 基本数据类型 数据类型 存储内容 示例 integer 整 float 浮点 ...
- 基于FPGA的彩色图像转灰度算法实现
昨天才更新了两篇博客,今天又要更新了,并不是我垃圾产,只不过这些在上个月就已经写好了,只是因为比赛忙,一直腾不出时间整理出来发表而已,但是做完一件事情总感觉不写一博文总结一下就少点什么,所以之后的一段 ...
- Thinkphp 3.0-3.1版代码执行漏洞
近日360库带计划中播报的ThinkPHP扩展类库的漏洞已经查明原因:系官方扩展模式中的Lite精简模式中存在可能的漏洞(原先核心更新安全的时候 并没有更新模式扩展部分,现已更新).对于使用标准模式或 ...
- mac Path had bad ownership/permissions
解决方案: http://stackoverflow.com/questions/28063598/error-while-executing-plist-file-path-had-bad-owne ...
- CentOS升级Python2.7导致使用pip等命令安装模块失败
报错如下: # pip Traceback (most recent call last): File , in <module> from pkg_resources import lo ...
- Dalvik详解
整理自百度百科 Dalvik Dalvik是Google公司自己设计用于Android平台的Java虚拟机.Dalvik虚拟机是Google等厂商合作开发的Android移动设备平台的核心组成部分之一 ...
- getElementById和querySelector方法的区别
"querySelector 属于 W3C 中的 Selectors API 规范 .而 getElementsBy 系列则属于 W3C 的 DOM 规范" 1.区别 getXXX ...
- openvpn配置注意事项
1.安装VPN安装结束后,需要配置CONFIG文件夹服务端及客户端的配置文件,建议从sample文件里直接拷贝修改,网上的一些案例会引起无法启动的问题,没仔细研究过是哪里错了,反正最后从sample里 ...
- [0] (VDP)垂直开发模式
垂直管理 网格化管理 属地管理 横向管理 面向接口编程 面向对象编程(OOP) 设计模式(GOF.MVC.SOA) 依赖注入(DI/IoC) 面向方面编程(AOP) 领域驱动开发(DDD) 测试驱动开 ...