二叉树的先序创建,先序,中序,后序的递归与非递归遍历,层次遍历,叶子结点数及树的深度

本文主要是介绍二叉树的先序创建,先序,中序,后序的递归与非递归遍历,层次遍历,叶子结点数及树的深度,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

二叉树的先序创建,先序,中序,后序的递归与非递归遍历,层次遍历,叶子结点数及树的深度计算

输入格式:如   abd###ce##f##*

 

package tree;
//二叉树的二叉链表实现
import java.util.LinkedList;
import java.util.Queue;
import java.util.Scanner;
import java.util.Stack;
public class BTree<AnyType> {
BTNode rootNode=new BTNode();
class BTNode<AnyType>{
char data;
BTNode<AnyType> leftChildNode;
BTNode<AnyType> rightChildNode;
public BTNode(){
data=0;
leftChildNode=rightChildNode=null;
}
public BTNode(char data){
this.data=data;
leftChildNode=rightChildNode=null;
}
public BTNode(char data,BTNode leftChildNode,BTNode rightChildNode){
this.data=data;
leftChildNode=leftChildNode;
rightChildNode=rightChildNode;
}
}
//先序创建二叉树
char d[]=new char[100];
int i=0;
public BTNode creatBTree(){
BTNode node=null;
if(d[i]!='*'){
if(d[i]=='#'){
node=null;
i++;
}
else{
node=new BTNode(d[i]);
i++; 
node.leftChildNode=creatBTree();   
node.rightChildNode=creatBTree();			
}
}
return node;
}
//先序递归遍历
public void preOrder(BTNode<AnyType> t){
if(t!=null){
System.out.print(t.data);
preOrder(t.leftChildNode);
preOrder(t.rightChildNode);
}
}
//先序非递归遍历
public void preStackOrder(BTNode t){
Stack s=new Stack();
BTNode p=t;
while(p!=null&&s.isEmpty()!=true){
if(p!=null){
System.out.print(p.data);
s.push(p);
p=p.leftChildNode;
}
if(s.isEmpty()){
s.pop();
p=p.rightChildNode;
}
}
}
//中序递归遍历
public void inOrder(BTNode t){
if(t!=null){
inOrder(t.leftChildNode);
System.out.print(t.data);
inOrder(t.rightChildNode);
}
}
//中序非递归遍历
public void inStackOrder(BTNode t){
Stack<BTNode> s=new Stack<BTNode>();
BTNode p=t;
while(p!=null&&s.isEmpty()){
if(p!=null){
s.push(p);
p=p.leftChildNode;
}
if(s.isEmpty()!=true){
p=s.pop();
System.out.print(p.data);
p=p.rightChildNode;
}
}
}
//后序递归遍历
public void postOrder(BTNode t){
if(t!=null){
postOrder(t.leftChildNode);
postOrder(t.rightChildNode);
System.out.print(t.data);
}
}
//后序非递归遍历
public void postStackOrder(BTNode t){
Stack<BTNode> s=new Stack<BTNode>();
Stack<Integer> ss=new Stack<Integer>();
Integer i=new Integer(1);
BTNode p=t;
BTNode q=t;
while(p!=null||s.isEmpty()!=true){	
while(p!=null){
s.push(p);
ss.push(new Integer(0));
p=p.leftChildNode;	
}
while(s.isEmpty()!=true&&ss.peek().equals(i)){
ss.pop();
q=s.pop();
System.out.print(q.data);	
}
if(s.isEmpty()!=true){
ss.pop();
ss.push(i);
p=s.peek();
p=p.rightChildNode;	
}	
}	
}
//层次非递归遍历
public void levelQueueOrder(BTNode t){
Queue<BTNode> q=new LinkedList<BTNode>();
q.add(t);
while(q.isEmpty()!=true){
BTNode step=q.remove();
System.out.print(step.data);
if(step.leftChildNode!=null){
q.add(step.leftChildNode);
}
if(step.rightChildNode!=null){
q.add(step.rightChildNode);
}
}
}
//计算二叉树深度
public int depth(BTNode t){
int leftDepth,rightDepth;
if(t==null) 
return 0;
leftDepth=depth(t.leftChildNode);
rightDepth=depth(t.rightChildNode);
return Math.max(leftDepth,rightDepth)+1;
}
//叶子结点个数
int num=0;
public int leaf(BTNode t){
if(t!=null){
if(t.leftChildNode==null&&t.rightChildNode==null)
num++;
leaf(t.leftChildNode);
leaf(t.rightChildNode);
}
return num;
}
public static void main(String[] args) {
BTree bt=new BTree();
Scanner sc=new Scanner(System.in);
String a=sc.next();
char c[]=a.toCharArray();
for(int i=0;i<c.length;i++){
bt.d[i]=c[i];
}
bt.rootNode=bt.creatBTree();
System.out.println("先序遍历");
bt.preOrder(bt.rootNode);
System.out.println();
System.out.println("中序遍历");
bt.inOrder(bt.rootNode);
System.out.println();
System.out.println("后序遍历");
bt.postOrder(bt.rootNode);
System.out.println();
System.out.println("后序非递归遍历");
bt.postStackOrder(bt.rootNode);
System.out.println("层次遍历");
bt.levelQueueOrder(bt.rootNode);
System.out.println();
System.out.println("二叉树深度");
System.out.println(bt.depth(bt.rootNode));
System.out.println("叶子结点个数");
System.out.println(bt.leaf(bt.rootNode));
}
}

这篇关于二叉树的先序创建,先序,中序,后序的递归与非递归遍历,层次遍历,叶子结点数及树的深度的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1088835

相关文章

JAVA中整型数组、字符串数组、整型数和字符串 的创建与转换的方法

《JAVA中整型数组、字符串数组、整型数和字符串的创建与转换的方法》本文介绍了Java中字符串、字符数组和整型数组的创建方法,以及它们之间的转换方法,还详细讲解了字符串中的一些常用方法,如index... 目录一、字符串、字符数组和整型数组的创建1、字符串的创建方法1.1 通过引用字符数组来创建字符串1.2

Node.js 中 http 模块的深度剖析与实战应用小结

《Node.js中http模块的深度剖析与实战应用小结》本文详细介绍了Node.js中的http模块,从创建HTTP服务器、处理请求与响应,到获取请求参数,每个环节都通过代码示例进行解析,旨在帮... 目录Node.js 中 http 模块的深度剖析与实战应用一、引言二、创建 HTTP 服务器:基石搭建(一

手把手教你idea中创建一个javaweb(webapp)项目详细图文教程

《手把手教你idea中创建一个javaweb(webapp)项目详细图文教程》:本文主要介绍如何使用IntelliJIDEA创建一个Maven项目,并配置Tomcat服务器进行运行,过程包括创建... 1.启动idea2.创建项目模板点击项目-新建项目-选择maven,显示如下页面输入项目名称,选择

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

在cscode中通过maven创建java项目

在cscode中创建java项目 可以通过博客完成maven的导入 建立maven项目 使用快捷键 Ctrl + Shift + P 建立一个 Maven 项目 1 Ctrl + Shift + P 打开输入框2 输入 "> java create"3 选择 maven4 选择 No Archetype5 输入 域名6 输入项目名称7 建立一个文件目录存放项目,文件名一般为项目名8 确定

Java 创建图形用户界面(GUI)入门指南(Swing库 JFrame 类)概述

概述 基本概念 Java Swing 的架构 Java Swing 是一个为 Java 设计的 GUI 工具包,是 JAVA 基础类的一部分,基于 Java AWT 构建,提供了一系列轻量级、可定制的图形用户界面(GUI)组件。 与 AWT 相比,Swing 提供了许多比 AWT 更好的屏幕显示元素,更加灵活和可定制,具有更好的跨平台性能。 组件和容器 Java Swing 提供了许多

基于UE5和ROS2的激光雷达+深度RGBD相机小车的仿真指南(五):Blender锥桶建模

前言 本系列教程旨在使用UE5配置一个具备激光雷达+深度摄像机的仿真小车,并使用通过跨平台的方式进行ROS2和UE5仿真的通讯,达到小车自主导航的目的。本教程默认有ROS2导航及其gazebo仿真相关方面基础,Nav2相关的学习教程可以参考本人的其他博客Nav2代价地图实现和原理–Nav2源码解读之CostMap2D(上)-CSDN博客往期教程: 第一期:基于UE5和ROS2的激光雷达+深度RG

韦季李输入法_输入法和鼠标的深度融合

在数字化输入的新纪元,传统键盘输入方式正悄然进化。以往,面对实体键盘,我们常需目光游离于屏幕与键盘之间,以确认指尖下的精准位置。而屏幕键盘虽直观可见,却常因占据屏幕空间,迫使我们在操作与视野间做出妥协,频繁调整布局以兼顾输入与界面浏览。 幸而,韦季李输入法的横空出世,彻底颠覆了这一现状。它不仅对输入界面进行了革命性的重构,更巧妙地将鼠标这一传统外设融入其中,开创了一种前所未有的交互体验。 想象

顺序表之创建,判满,插入,输出

文章目录 🍊自我介绍🍊创建一个空的顺序表,为结构体在堆区分配空间🍊插入数据🍊输出数据🍊判断顺序表是否满了,满了返回值1,否则返回0🍊main函数 你的点赞评论就是对博主最大的鼓励 当然喜欢的小伙伴可以:点赞+关注+评论+收藏(一键四连)哦~ 🍊自我介绍   Hello,大家好,我是小珑也要变强(也是小珑),我是易编程·终身成长社群的一名“创始团队·嘉宾”

Maven创建项目中的groupId, artifactId, 和 version的意思

文章目录 groupIdartifactIdversionname groupId 定义:groupId 是 Maven 项目坐标的第一个部分,它通常表示项目的组织或公司的域名反转写法。例如,如果你为公司 example.com 开发软件,groupId 可能是 com.example。作用:groupId 被用来组织和分组相关的 Maven artifacts,这样可以避免