PS:输入测试数据时候采用先序遍历的方式用#作为分隔符来输入,例如:此二叉树
用这种方式输入ABC##DE#G##F###
package cn.jinyejun.experiment_Tree; public class BNode{ int data; BNode lchild; BNode rchild; }
package cn.jinyejun.experiment_Tree; import java.util.LinkedList; import java.util.Queue; import java.util.Scanner; import java.util.Stack; public class BinTree { static int index = 0; static class Info { int numOfNode = 0; int degree_1 = 0; int degree_2 = 0; int numOflNode = 0; int maxData; int minData; } public static void main(String[] args) { Scanner cin = new Scanner(System.in); String toBuild = cin.nextLine(); BNode bd = buildTree(toBuild); System.out.print("先序遍历: "); preOrder(bd); System.out.println(); System.out.print("中序遍历: "); inOrder(bd); System.out.println(); System.out.print("后序遍历: "); postOrder(bd); System.out.println(); Info info = Non_recursive(bd); System.out.println("二叉树节点数: " + info.numOfNode + " 度为1节点数 :" + info.degree_1 + " 度为2节点数:" + info.degree_2 + " 叶节点数: " + info.numOflNode + " 最大数据 :" + info.maxData + " 最小数据: " + info.minData); System.out.print("层次遍历: "); levOrder(bd); System.out.println(); } // 建二叉树(采用先序的算法建树) public static BNode buildTree(String str) { BNode bd; char ch = str.charAt(index++); if (ch == '#') { return null; } else { bd = new BNode(); bd.data = (int)ch-48; bd.lchild = buildTree(str); bd.rchild = buildTree(str); return bd; } } // 先序遍历 public static void preOrder(BNode bd) { if (bd != null) { System.out.print(bd.data + " "); preOrder(bd.lchild); preOrder(bd.rchild); } } // 中序遍历 public static void inOrder(BNode bd) { if (bd != null) { inOrder(bd.lchild); System.out.print(bd.data + " "); inOrder(bd.rchild); } } // 后续遍历 public static void postOrder(BNode bd) { if (bd != null) { postOrder(bd.lchild); postOrder(bd.rchild); System.out.print(bd.data + " "); } } //层次遍历 public static void levOrder(BNode bd){ Queue<BNode> queue = new LinkedList<BNode>(); BNode tempbd; if(bd !=null){ queue.offer(bd); } while(!queue.isEmpty()){ tempbd = queue.poll(); System.out.print(tempbd.data+" "); if(tempbd.lchild!=null){ queue.offer(tempbd.lchild); } if(tempbd.rchild!=null){ queue.offer(tempbd.rchild); } } } // 非递归统计二叉树的节点个数、度为1、度为2和叶子节点的个数,以及数据值的最大值和最小值 public static Info Non_recursive(BNode bd) { Stack<BNode> st = new Stack<BNode>(); Info info = new Info(); BNode tempBd; int degree; //初始化最大值最小值 if (bd != null) { st.push(bd); info.maxData = bd.data; info.minData = bd.data; info.numOfNode++; } while (!st.isEmpty()) { //每次遍历节点计算度 degree = 0; tempBd = st.pop(); info.maxData = (tempBd.data > info.maxData) ? tempBd.data : info.maxData; info.minData = (tempBd.data < info.minData) ? tempBd.data : info.minData; if (tempBd.rchild != null) { st.push(tempBd.rchild); info.numOfNode++; degree++; } if (tempBd.lchild != null) { st.push(tempBd.lchild); info.numOfNode++; degree++; } //如果度为0,说明就是叶节点,如果为1或2统计度为1或2的节点数 switch (degree) { case 0: info.numOflNode++; break; case 1: info.degree_1++; break; case 2: info.degree_2++; break; } } return info; } }
相关推荐
这通常涉及到对二叉树节点的定位算法,比如使用层次遍历(广度优先搜索BFS)来确定节点的位置,并在画布上绘制出节点和连接线。 此外,实现这些功能时,还需要关注一些技术细节,例如: - **内存管理**:在构建...
本压缩包文件“BinTreeBasic”包含了关于二叉树基本操作的实现,特别是非递归方式的前序、中序和后序遍历。 首先,我们来详细解释二叉树的三种遍历方式: 1. **前序遍历**:也称为先根遍历,其顺序为根节点 -> 左...
总结,本主题涵盖了二叉树的基本操作,包括通过先序序列构建二叉树,以及使用递归和非递归方法进行先序、中序、后序和层次遍历。同时,也涉及了如何计算二叉树的深度,这些都是理解和操作二叉树所必备的基础知识。...
【二叉树遍历】是计算机科学中对二叉树数据结构进行操作的一种基本方法,主要分为三种类型:先序遍历、中序遍历和后序遍历。这三种遍历方式对于理解和操作二叉树至关重要,尤其在查找、插入和删除操作中。 **先序...
用函数实现如下二叉排序树算法:(1) 插入新结点(2) 前序、中序、后序遍历二叉树(3) 中序遍历的非递归算法(4) 层次遍历二叉树(5) 在二叉树中查找给定关键字(函数返回值为成功1,失败0) Input 第一行:准备...
(4) 层次遍历二叉树 (5) 在二叉树中查找给定关键字(函数返回值为成功1,失败0) (6) 交换各结点的左右子树 (7) 求二叉树的深度 (8) 叶子结点数 Input 第一行:准备建树的结点个数n 第二行:输入n个...
1. **二叉树遍历**:包括递归和非递归方式实现二叉树的前序、中序、后序遍历,以及层次遍历。建树的实现也是关键部分,有助于理解二叉树的构造。 2. **车厢调度问题**:这是一个排列组合问题,要求设计程序生成所有...
本主题主要探讨如何在Windows环境下,使用C#语言实现二叉树的建立与遍历,包括先序遍历、中序遍历、后序遍历和层次遍历。 **一、二叉树的建立** 在C#中,我们首先需要定义一个二叉树节点类,它包含值、左子节点和...
在二叉树中,常用的遍历算法有先序遍历、中序遍历和后序遍历。先序遍历是先访问根结点,然后递归访问左子树和右子树;中序遍历是先访问左子树,然后访问根结点,最后访问右子树;后序遍历是先访问左子树和右子树,...
本程序以C++语言实现,提供了二叉树的基本操作,包括创建二叉树、前序遍历、中序遍历、后序遍历、删除节点、计算节点数量以及求解树的高度等。下面将详细解释这些操作。 1. **建树**:构建二叉树的过程通常涉及根据...
这里有四种常见的遍历方法:先序遍历(根-左-右)、中序遍历(左-根-右)、后序遍历(左-右-根)以及层次遍历(按层级从左到右)。对于递归版本的遍历,我们可以这样实现: 1. 先序遍历: ```cpp void ...
任务 :编程实现二叉树的建立,先序(递归和非递归方法)、中序、后序、层次遍历,求二叉树的高度; 要求:从文件中读入建树信息,树的节点数目不小于20个,树的高度不小于4; 3、Hash表应用 问题描述:设计散列表...
2、实现1所要求的代码后,运行设计好的代码,将以下的几组整数序列建成搜索二叉树,并记录下它们的前序遍历序列和后序遍历序列: a. 1、3、5、7、9; b. 1、13、35、13、27; c. 50、25、78、13、44、...
遍历中序线索二叉树(Inorder_thlinked) 中序线索树的插入(ins_lchild_inthr)和删除(del_lchild_inthr)结点 (4)建赫夫曼树和求赫夫曼编码(HuffmanCoding) (5)森林转化成二叉树(Forest2BT) (6)二叉树...
遍历中序线索二叉树(Inorder_thlinked) 中序线索树的插入(ins_lchild_inthr)和删除(del_lchild_inthr)结点 (4)建赫夫曼树和求赫夫曼编码(HuffmanCoding) (5)森林转化成二叉树(Forest2BT) (6)二叉树...