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
}
}
分享到:
相关推荐
### 二叉树遍历的特点(数据结构) 在计算机科学领域,数据结构是研究的核心之一。其中,二叉树作为一种重要的非线性数据结构,在实际应用中极为广泛,包括搜索算法、排序算法等方面都有其身影。本文将详细介绍...
二叉树的遍历C语言二叉树遍历实例C语言二叉树遍历实例C语言二叉树遍历实例C语言二叉树遍历实例C语言二叉树遍历实例C语言二叉树遍历实例C语言二叉树遍历实例C语言二叉树遍历实例C语言二叉树遍历实例C语言二叉树遍历...
二叉树遍历是理解数据结构和算法的基础,它包括前序遍历、中序遍历和后序遍历三种主要方法。 1. **二叉树的基本概念**: - 二叉树是一种特殊的树结构,每个节点最多有两个子节点,通常称为左子节点和右子节点。 -...
二叉树遍历是理解二叉树操作的关键部分,主要包括先序遍历、中序遍历和后序遍历三种方式。 1. 先序遍历(Preorder Traversal): 先序遍历的顺序是根节点 -> 左子树 -> 右子树。在C语言实现中,一般采用递归的方法...
二叉树遍历算法在IT领域中是一种基础且重要的数据结构操作技术,广泛应用于各种问题的解决。在本文中,我们将深入探讨二叉树遍历的原理及其在统计二叉树节点数量、叶子节点计数以及计算树深等方面的应用。 二叉树...
从给定的文件信息来看,该文件主要围绕“堆栈实现二叉树遍历数据结构”的主题,通过C语言编程来实现。以下是基于标题、描述、标签和部分内容的知识点总结和详细说明: ### 1. 数据结构基础 数据结构是计算机科学的...
二叉树遍历是针对这种数据结构的一种基本操作,用于按照特定顺序访问树中的所有节点。本程序实现了三种主要的二叉树遍历方法:先序遍历、中序遍历和后序遍历。以下是关于这些遍历方法的详细解释: 1. 先序遍历...
"数据结构树和二叉树遍历二叉树和线索二叉树PPT学习教案.pptx" 本资源主要讲述了数据结构树和二叉树遍历的相关知识点,包括二叉树的基本概念、二叉树遍历的六种方案、先序、中序、后序遍历算法的实现、线索二叉树的...
实验三 二叉树遍历与路径查找(二叉树实验) 实现功能:建立二叉树存储结构、求二叉树的先序遍历、求二叉树的中序遍历、求二叉树的后序遍历、求二叉树的层次遍历、求根到给定结点的路径。 主控菜单: 1.建立二叉树...
### MATLAB 实现二叉树遍历算法的知识点详解 #### 一、二叉树节点结构体定义 在MATLAB中实现二叉树的第一步是定义一个表示二叉树节点的结构体。在这个例子中,作者定义了一个名为`TreeNode`的类来表示节点,该类...
#### 1.2 二叉树遍历 遍历是指按照某种顺序访问二叉树中的所有节点,且每个节点只被访问一次的过程。二叉树常见的遍历方式包括:先序遍历、中序遍历和后序遍历。 ### 二、二叉树遍历方法 #### 2.1 先序遍历(前序...
java 写的算24程序。用两种二叉树遍历,并规整输出字符串
二叉树遍历 二叉树遍历
二叉树遍历是计算机科学中处理树结构数据时常用的一种技术,主要分为四种类型:先序遍历、中序遍历、后序遍历和宽度优先遍历。这些遍历方法各有特点,适用于不同的场景。 1. **先序遍历**: - **递归实现**:先...
二叉树遍历是计算机科学中数据结构领域的一个重要概念,尤其在算法设计与分析中占有举足轻重的地位。二叉树是一种特殊的图结构,每个节点最多有两个子节点,通常分为左子节点和右子节点。二叉树遍历是指按照特定顺序...
二叉树遍历是计算机科学中的一个重要概念,主要应用于数据结构和算法领域。二叉树是一种特殊的树形数据结构,每个节点最多有两个子节点,通常称为左子节点和右子节点。二叉树遍历是指按照特定顺序访问二叉树的所有...
二叉树遍历问题 二叉树遍历问题-前序, 中序, 后序二叉树遍历问题-前序, 中序, 后序二叉树遍历问题-前序, 中序, 后序二叉树遍历问题-前序, 中序, 后序二叉树遍历问题-前序, 中序, 后序二叉树遍历问题-前序...
二叉树遍历操作.cpp