二叉树简单实现(创建、遍历、叶子数等)

2023-10-06 15:19

本文主要是介绍二叉树简单实现(创建、遍历、叶子数等),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

      直接代码吧,有问题可以讨论,基本都是采用递归的方式求解,创建二叉树,这个例子对于root结点只有左孩子:

#include "stdafx.h"
#include<stdlib.h>
#include "math.h"
#include <iostream>using namespace std;typedef struct BiTreeNode
{char data;BiTreeNode *left;BiTreeNode *right;
}BiTreeNode,*PBiTreeNode;
static int iCnt = 0;
void CreateBiTree(PBiTreeNode &Tree)//创建二叉树
{char s[]="ABC$$D$EF$$G$$$";char ch = s[iCnt++];if ( ch == '$' )//$代表不存在Tree = NULL;else{Tree = (PBiTreeNode)malloc(sizeof(BiTreeNode));if (!Tree)exit(OVERFLOW);Tree->data = ch;CreateBiTree(Tree->left);CreateBiTree(Tree->right);}
}void PreOder(PBiTreeNode Tree)//先序遍历
{if ( !Tree )return;cout << Tree->data << endl;if ( Tree->left )PreOder( Tree->left );if ( Tree->right )PreOder( Tree->right);
}
void InOder(PBiTreeNode Tree)//中序遍历
{if ( !Tree )return;if ( Tree->left )InOder( Tree->left );cout << Tree->data << endl;if ( Tree->right )InOder( Tree->right );
}
void PostOder(PBiTreeNode Tree)//后序遍历
{if ( !Tree )return;if ( Tree->left )InOder( Tree->left );if ( Tree->right )InOder( Tree->right );cout << Tree->data << endl;
}void PrintBiTree(PBiTreeNode Tree)//打印二叉树
{if ( !Tree )return;cout << Tree->data << endl;if ( Tree->left || Tree->right ){cout <<"(";PrintBiTree(Tree->left);if ( !Tree->right )cout <<",";PrintBiTree(Tree->right);cout <<")";}
}
int TreeDepth(PBiTreeNode Tree) //二叉树的深度
{int lDepth = 0, rDepth = 0;if ( !Tree )return 0;lDepth = TreeDepth( Tree->left );rDepth = TreeDepth( Tree->right );return lDepth > rDepth ? (lDepth + 1) : (rDepth + 1);
}int LeavesNum(PBiTreeNode Tree)//叶子数
{if ( !Tree )return 0;else if ( !Tree->left && !Tree->right )return 1;elsereturn LeavesNum( Tree->left ) + LeavesNum( Tree->right );
}void DestroyBiTree(PBiTreeNode &Tree)
{if ( !Tree)return;else{DestroyBiTree( Tree->left );DestroyBiTree( Tree->right);free(Tree);Tree = NULL;}
}
int main()
{PBiTreeNode Tree;CreateBiTree( Tree );cout <<"输出二叉树:"<<endl;PrintBiTree( Tree );cout << endl;cout <<"先序遍历结果:"<<endl;PreOder( Tree );cout <<"中序遍历结果:"<<endl;InOder( Tree );cout <<"后序遍历结果:"<<endl;PostOder( Tree );cout <<"树的高度:"<<TreeDepth( Tree )<<endl;cout <<"叶子结点个数:"<< LeavesNum( Tree )<<endl;DestroyBiTree( Tree );
}


这篇关于二叉树简单实现(创建、遍历、叶子数等)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Linux线程之线程的创建、属性、回收、退出、取消方式

《Linux线程之线程的创建、属性、回收、退出、取消方式》文章总结了线程管理核心知识:线程号唯一、创建方式、属性设置(如分离状态与栈大小)、回收机制(join/detach)、退出方法(返回/pthr... 目录1. 线程号2. 线程的创建3. 线程属性4. 线程的回收5. 线程的退出6. 线程的取消7.

Linux下删除乱码文件和目录的实现方式

《Linux下删除乱码文件和目录的实现方式》:本文主要介绍Linux下删除乱码文件和目录的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux下删除乱码文件和目录方法1方法2总结Linux下删除乱码文件和目录方法1使用ls -i命令找到文件或目录

SpringBoot+EasyExcel实现自定义复杂样式导入导出

《SpringBoot+EasyExcel实现自定义复杂样式导入导出》这篇文章主要为大家详细介绍了SpringBoot如何结果EasyExcel实现自定义复杂样式导入导出功能,文中的示例代码讲解详细,... 目录安装处理自定义导出复杂场景1、列不固定,动态列2、动态下拉3、自定义锁定行/列,添加密码4、合并

mybatis执行insert返回id实现详解

《mybatis执行insert返回id实现详解》MyBatis插入操作默认返回受影响行数,需通过useGeneratedKeys+keyProperty或selectKey获取主键ID,确保主键为自... 目录 两种方式获取自增 ID:1. ​​useGeneratedKeys+keyProperty(推

Spring Boot集成Druid实现数据源管理与监控的详细步骤

《SpringBoot集成Druid实现数据源管理与监控的详细步骤》本文介绍如何在SpringBoot项目中集成Druid数据库连接池,包括环境搭建、Maven依赖配置、SpringBoot配置文件... 目录1. 引言1.1 环境准备1.2 Druid介绍2. 配置Druid连接池3. 查看Druid监控

Linux在线解压jar包的实现方式

《Linux在线解压jar包的实现方式》:本文主要介绍Linux在线解压jar包的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux在线解压jar包解压 jar包的步骤总结Linux在线解压jar包在 Centos 中解压 jar 包可以使用 u

创建Java keystore文件的完整指南及详细步骤

《创建Javakeystore文件的完整指南及详细步骤》本文详解Java中keystore的创建与配置,涵盖私钥管理、自签名与CA证书生成、SSL/TLS应用,强调安全存储及验证机制,确保通信加密和... 目录1. 秘密键(私钥)的理解与管理私钥的定义与重要性私钥的管理策略私钥的生成与存储2. 证书的创建与

c++ 类成员变量默认初始值的实现

《c++类成员变量默认初始值的实现》本文主要介绍了c++类成员变量默认初始值,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录C++类成员变量初始化c++类的变量的初始化在C++中,如果使用类成员变量时未给定其初始值,那么它将被

Qt使用QSqlDatabase连接MySQL实现增删改查功能

《Qt使用QSqlDatabase连接MySQL实现增删改查功能》这篇文章主要为大家详细介绍了Qt如何使用QSqlDatabase连接MySQL实现增删改查功能,文中的示例代码讲解详细,感兴趣的小伙伴... 目录一、创建数据表二、连接mysql数据库三、封装成一个完整的轻量级 ORM 风格类3.1 表结构

基于Python实现一个图片拆分工具

《基于Python实现一个图片拆分工具》这篇文章主要为大家详细介绍了如何基于Python实现一个图片拆分工具,可以根据需要的行数和列数进行拆分,感兴趣的小伙伴可以跟随小编一起学习一下... 简单介绍先自己选择输入的图片,默认是输出到项目文件夹中,可以自己选择其他的文件夹,选择需要拆分的行数和列数,可以通过