`
hellojyj
  • 浏览: 62100 次
  • 性别: Icon_minigender_1
  • 来自: 长沙
社区版块
存档分类
最新评论

二叉树的建树,先序,中序,后序,层次遍历

阅读更多

 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;
	}
}

 

 

  • 大小: 26.2 KB
分享到:
评论

相关推荐

    二叉树的先序建立,递归非递归遍历

    这通常涉及到对二叉树节点的定位算法,比如使用层次遍历(广度优先搜索BFS)来确定节点的位置,并在画布上绘制出节点和连接线。 此外,实现这些功能时,还需要关注一些技术细节,例如: - **内存管理**:在构建...

    二叉树基本操作(建树、前中后序遍历非递归实现)

    本压缩包文件“BinTreeBasic”包含了关于二叉树基本操作的实现,特别是非递归方式的前序、中序和后序遍历。 首先,我们来详细解释二叉树的三种遍历方式: 1. **前序遍历**:也称为先根遍历,其顺序为根节点 -&gt; 左...

    二叉树深度+建树+查找+遍历二叉树

    总结,本主题涵盖了二叉树的基本操作,包括通过先序序列构建二叉树,以及使用递归和非递归方法进行先序、中序、后序和层次遍历。同时,也涉及了如何计算二叉树的深度,这些都是理解和操作二叉树所必备的基础知识。...

    二叉树的遍历实验报告.docx

    【二叉树遍历】是计算机科学中对二叉树数据结构进行操作的一种基本方法,主要分为三种类型:先序遍历、中序遍历和后序遍历。这三种遍历方式对于理解和操作二叉树至关重要,尤其在查找、插入和删除操作中。 **先序...

    数据结构 实现二叉排序树的各种算法(1)

    用函数实现如下二叉排序树算法:(1) 插入新结点(2) 前序、中序、后序遍历二叉树(3) 中序遍历的非递归算法(4) 层次遍历二叉树(5) 在二叉树中查找给定关键字(函数返回值为成功1,失败0) Input 第一行:准备...

    数据结构 实现二叉排序树的各种算法(2)

    (4) 层次遍历二叉树 (5) 在二叉树中查找给定关键字(函数返回值为成功1,失败0) (6) 交换各结点的左右子树 (7) 求二叉树的深度 (8) 叶子结点数 Input 第一行:准备建树的结点个数n 第二行:输入n个...

    数据结构与算法专业课程设计专题计划数学与计算机系信计本科.doc

    1. **二叉树遍历**:包括递归和非递归方式实现二叉树的前序、中序、后序遍历,以及层次遍历。建树的实现也是关键部分,有助于理解二叉树的构造。 2. **车厢调度问题**:这是一个排列组合问题,要求设计程序生成所有...

    二叉树的建立与遍历 windows 实现

    本主题主要探讨如何在Windows环境下,使用C#语言实现二叉树的建立与遍历,包括先序遍历、中序遍历、后序遍历和层次遍历。 **一、二叉树的建立** 在C#中,我们首先需要定义一个二叉树节点类,它包含值、左子节点和...

    北理工数据结构作业3.pdf

    在二叉树中,常用的遍历算法有先序遍历、中序遍历和后序遍历。先序遍历是先访问根结点,然后递归访问左子树和右子树;中序遍历是先访问左子树,然后访问根结点,最后访问右子树;后序遍历是先访问左子树和右子树,...

    用C++实现二叉树的基本操作。

    本程序以C++语言实现,提供了二叉树的基本操作,包括创建二叉树、前序遍历、中序遍历、后序遍历、删除节点、计算节点数量以及求解树的高度等。下面将详细解释这些操作。 1. **建树**:构建二叉树的过程通常涉及根据...

    二叉树创建及遍历(vc6.0)

    这里有四种常见的遍历方法:先序遍历(根-左-右)、中序遍历(左-根-右)、后序遍历(左-右-根)以及层次遍历(按层级从左到右)。对于递归版本的遍历,我们可以这样实现: 1. 先序遍历: ```cpp void ...

    数据结构课设 各种排序

    任务 :编程实现二叉树的建立,先序(递归和非递归方法)、中序、后序、层次遍历,求二叉树的高度; 要求:从文件中读入建树信息,树的节点数目不小于20个,树的高度不小于4; 3、Hash表应用 问题描述:设计散列表...

    数据结构(C++)有关练习题

    2、实现1所要求的代码后,运行设计好的代码,将以下的几组整数序列建成搜索二叉树,并记录下它们的前序遍历序列和后序遍历序列: a. 1、3、5、7、9; b. 1、13、35、13、27; c. 50、25、78、13、44、...

    用c描述的数据结构演示软件

     遍历中序线索二叉树(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)二叉树...

Global site tag (gtag.js) - Google Analytics