网上看到的一个二叉树,自己放到myeclipse实现了一下,但具体的在什么场景下应用还不太清楚,网上也没有找到相应的文章介绍。又重新修改了一下,还是有些地方不太明白。在建立二叉树的时候传入的数组的顺序怎么确定?一个很困扰的问题!
package algorithm;
import java.util.Stack;
/**
* May 27, 2009
* version 1.1
*/
public class BinaryTree {
// Root node pointer. Will be null for an empty tree.
private Node root ;
private static class Node {
Node left ;
Node right ;
int data ;
Node( int newData) {
left = null ;
right = null ;
data = newData;
}
}
/**
Creates an empty binary tree -- a null root pointer.
*/
public BinaryTree() {
root = null ;
}
/**
Inserts the given data into the binary tree.
Uses a recursive helper.
*/
public void insert( int data) {
// System.out.println(data);
root = insert( root , data);
}
/**
Recursive insert -- given a node pointer, recur down and
insert the given data into the tree. Returns the new
node pointer (the standard way to communicate
a changed pointer back to the caller).
二叉搜索树
*/
private Node insert(Node node, int data) {
if (node== null ) {
node = new Node(data);
}else {
if (data <= node. data ) {
// System.out.println("left:"+data);
node. left = insert(node. left , data);
}else {
// System.out.println("right:"+data);
node. right = insert(node. right , data);
}
}
return (node); // in any case, return the new pointer to the caller
}
public void buildTree( int [] data){
for ( int i=0;i<data.length ;i++){
insert(data[i]);
}
}
public void printTree() {
afterErgodic( root );
System. out .println();
}
private void printTree(Node node) {
if (node == null ) return ;
// left, node itself, right
printTree(node. left );
System. out .print(node. data + " " );
printTree(node. right );
}
/**
* 先序遍历
* @param node
*/
public void preErgodic(Node node){
if(node==null){
return;
}
Stack sk=new Stack();
Node p=node;
while(p!=null){
//把p节点的左子树的左子树的值获取出来
//把p节点的右子节点入栈,最上面的是右叶子节点
//栈底的节点为根的右子节点
while(p!=null){
System.out.print(p.data+" ");
//右子树入栈
if(p.right!=null) sk.push(p.right);
//进入下一个左子树
p=p.left;
}
//遍历右子树,从右叶子节点开始,然后往上,若有左子节点,则执行上面的while步骤
if(!sk.isEmpty()){
//进入下一个右子树
p=(Node)sk.pop();
// System.out.print(p.data+ " ");
}
}
}
/**
* 中序遍历
* @param node
*/
public void centerErgodic(Node node){
if(node==null){
return;
}
Stack sk=new Stack();
Node p=node;
while(p!=null||!sk.isEmpty()){
//把p节点的左子节点入栈,最上面的是左叶子节点
while(p!=null){
sk.push(p);
p=p.left;
}
//第一步是先把左叶子节点出栈,此时右节点为null
//第二步是把左叶子节点的父节点出栈,此时的右节点则是右叶子节点
//第三步则是把左叶子节点的父节点的父节点出栈,此时右节点含有子节点
//第四步开始则是对右节点开始遍历,步骤则是重复前三步
//第五步则是重复执行第三步和第四步,直到sk里面无节点为止
if(!sk.isEmpty()){
p=(Node)sk.pop();
System.out.print(p.data+" ");
p=p.right;
}
}
}
/**
* 后序遍历
* @param node
*/
public void afterErgodic(Node node){
if(node==null){
return;
}
Stack sk=new Stack();
Node p=node;
while(p!=null||!sk.isEmpty()){
//先左后右不断深入
while(p!=null){
sk.push(p);//将根节点入栈
if(p.left!=null) p=p.left;
else p=p.right;
}
//这里主要是叶子节点的获取
if(!sk.isEmpty()){
p=(Node)sk.pop();
System.out.print(p.data+" ");
}
//满足条件时,说明栈顶根节点右子树已访问,应出栈访问之
//这里肯定是非叶子节点
while(!sk.isEmpty()&&((Node)sk.peek()).right==p){
p=(Node)sk.pop();
System.out.print(p.data+" ");
}
//转向栈顶根节点的右子树继续后序遍历
if(!sk.isEmpty()) p=((Node)sk.peek()).right;
else p=null;
}
}
/**
* 另外一种建立二叉树的方法,非递归形式
* @param data
*/
public void createBinary(int[] data){
Node temp = null;
for(int i=0;i<data.length;i++){
// 创建根节点
if(root==null){
root = temp = new Node(data[i]);
}else{
// 回到根结点
temp=root;
// 添加节点
while (temp.data != data[i]) {
if(temp.data>data[i]){//左子树
if (temp.left != null) {
// System.out.println(data[i]+" "+22);
//如果有左子树,则把左子树赋值给temp,此次while循环结束,开始下次循环。
//直到没有左子树为止,即新增加一个左子树
temp = temp.left;
}else{
//新增左子树
// System.out.println(data[i]+" "+11);
temp.left=new Node(data[i]);
//这里可以减少循环的次数,新增之后再判断时则会跳出循环
temp = temp.left;
}
}else{//右子树
if(temp.right!=null){
//同左子树
temp = temp.right;
}else{
temp.right=new Node(data[i]);
//同上
temp = temp.right;
}
}
}
}
}
// return root;
}
/**
* @param args
*/
public static void main(String[] args) {
BinaryTree bt=new BinaryTree();
//数据貌似不能是排好序的,但必须有顺序,貌似是前序遍历的顺序
int[] array={4, 2, 6, 1, 3, 5, 7};
// bt.buildTree(array);
bt.createBinary(array);
bt.printTree();
// # 4
// # / \
// # 2 6
// # / \ / \
// # 1 3 5 7
// # 前序遍历:4 2 1 3 6 5 7
// # 中序遍历:1 2 3 4 5 6 7
// # 后序遍历:1 3 2 5 7 6 4
}
}
分享到:
相关推荐
数据结构-二叉树Java实现及其遍历算法,代码示例中实现了中序遍历,简单易学。
在Java中实现二叉树,我们可以自定义一个类来表示树节点,并通过节点之间的连接来构建整个树形结构。这篇博客主要讨论了如何在Java中实现二叉树的基本操作,包括递归和非递归方式的三种遍历顺序:前序遍历、中序遍历...
平衡二叉树Java实现,平衡二叉树Java实现,平衡二叉树Java实现,平衡二叉树Java实现,
总结来说,理解和掌握二叉树以及如何用JAVA实现它们是成为优秀程序员的关键一步。通过实践,你可以更深入地了解数据结构的精髓,提升算法设计能力,并为解决复杂问题打下坚实基础。对于初学者,可以从简单的二叉树...
本文将深入探讨“数据结构 二叉树 java图形界面实现”这一主题,主要围绕二叉树的基本概念、常见操作以及如何在Java环境中结合图形界面进行实现。 首先,二叉树是一种非线性的数据结构,每个节点最多有两个子节点,...
代码实现: 二叉树的查找、插入、删除和输出根节点到当前节点的路径 二叉树的前序遍历,中序遍历和后续遍历 TreeNode.java --定义树节点 Mytree.java----创建树结构和上述功能函数 TestTree.java --测试上述的功能
java二叉树实现 (简单实现,入门用) /**创建二叉树*/ public BinaryTree createTree(String treeStr); /**寻找结点*/ public BinaryTree findNode(BinaryTree tree ,char sign); /**找所给结点的左子树*/ ...
后序遍历的Java实现通常使用栈来辅助操作: ```java public void postOrderTraversal(TreeNode node) { if (node == null) return; Stack<TreeNode> stack = new Stack(); TreeNode prev = null; while (node...
java实现二叉树非递归前序中序后序遍历
在本项目中,“基于JAVA开发的二叉树课程设计与实现”主要涵盖了计算机科学中的数据结构和算法领域,特别是关于二叉树的理论知识、Java编程语言的应用以及软件工程的基本实践。二叉树是一种重要的非线性数据结构,...
在Java中动态实现二叉树,即在运行时根据需要创建、更新和操作树结构,这涉及到对数据结构和Swing组件的深入理解。 首先,二叉树是一种特殊的树形数据结构,每个节点最多有两个子节点,分别称为左孩子和右孩子。...
下面是一些常见的二叉树操作的Java实现示例: 1. **创建二叉树**: 创建二叉树通常从空节点开始,通过插入节点来构造。例如,插入新节点的函数可能如下: ```java public void insert(int val) { root = insert...
编程实现如下功能: 1、假设二叉树的结点值是字符,根据输入的一颗二叉树的标明了空子树的完整先根遍历序列,建立一棵以二叉链表表示的二叉树。 2、对二叉树进行先根、中根和后根遍历操作,并输出遍历序列,同时观察...
总之,Java实现二叉树的最佳方法依赖于对二叉树性质的深入理解以及对Java语言特性的熟练应用。递归构建和遍历是实现二叉树的两个核心方面,它们共同构建了复杂二叉树算法的基石。在实际应用中,还需要考虑树结构的...
数据结构二叉树(Binary Tree)的Java实现; 包括最基本的清空方法/判断为空方法/求树的深度的方法/获得父结点的方法/获得左/右兄弟结点的方法/递归先序/中序/后序遍历二叉树的方法;
文档中是我自己实现的用java语言实现(1)判断给定的二叉树是否平衡;(2)二叉树插入新数据后,如果失衡自我旋转调整的方法。
1:构造一个二叉树 2:二叉树前序遍历(递归) 3:二叉树中序遍历(递归) 4:二叉树后续遍历(递归) 5:二叉树前序遍历(非递归) 6:二叉树中序遍历(非递归) 7:二叉树后序遍历(非递归)
在"二叉树java源码完整"这个项目中,我们可以期待找到用Java实现的二叉树类及其相关方法。源码通常会包括以下部分: 1. **基础定义**:首先,会有一个类(例如`BinaryTree`或者`Node`)来表示二叉树的节点,每个...
在这个Java实现中,我们可以看到一个完整的二叉树可视化系统,包括四个关键的Java源文件:BinaryNode、Show1_12、Display_Tree和TreeControl。 1. **BinaryNode.java**: 这个文件代表二叉树的基本节点。在Java中,...