C/C++【数据结构】一文秒懂二叉树

 个人主页:仍有未知等待探索_C语言疑难,数据结构,小项目-CSDN博客

专题分栏:数据结构_仍有未知等待探索的博客-CSDN博客

一、前言

树形结构是一类非常重要的非线性结构。树形结构是节点之间有分支,并且具有层次关系的结构,它类似于自然界中的树。

就比如说:电脑中磁盘中的文件储存方式就类似于一颗树。

二、树的定义和基本的术语

在讲二叉树之前,我们要先讲树的定义和树的一些术语。

1、树的定义

树是n(n>=0)个结点的有限集,T为空时称为空树。

非空树的特点:

  • T中有且仅有一个结点K,没有前驱,称K为树的根结点。
  • 除了根结点以外,其余节点有且仅有一个直接前驱。
  • T中各结点可以有0个或者多个后继。
  • 除了根节点以外,其余结点可以分为m个互不相干的有限集合。

2、树的基本术语

  • 一个节点拥有的子树个数称为结点的度
  • 度为零的结点称为叶子节点
  • 树的度是树中所有结点的度的最大值。
  • 结点子树的根称为孩子结点,该结点称为其双亲结点
  • 结点的祖先是从跟到该结点所经分支上的所有结点。
  • 某一结点的子孙是以该结点为根的子树上的任一结点。
  • 结点的层次:根为第一层,以此类推。
  • 树中最大的层次叫做树的深度(高度)
  • 树中结点的个子树可以看作是从左到右有次序的,称为有序树,反之无序树
  • 森林是m(m>=0)棵互不相交的树的集合。

三、二叉树 

1、二叉树的5种基本形态

2、二叉树的两种特殊形态 

(1)满二叉树

每层结点都是满的,即满二叉树的每层上的结点数都是最大结点数。

一共有2^n-1个结点(n为树的高度)

下图是高度为4的满二叉树 

(2)完全二叉树 

最多只有一个度为1的结点。

序号和满二叉树的一样。

3、二叉树的性质 

  1. 在二叉树的第i层上至多有 2^i - 1 个结点( i >= 1 )。
  2. 深度为k的二叉树至多有 2^k - 1 个结点( k >= 1 )。
  3. 设n0、n1、n2分别为度为0,1,2的结点,则 n0=n2+1
  4. 具有n个结点的完全二叉树的深度 [log2n]+1 
  5. n个完全二叉树,按照层序编号,i=1,其结点为根节点。若 i > 1,i/2 为其结点的双亲结点,2*i 为其左孩子的编号(2*i > n 无左孩子), 2*i+1为其右孩子的编号 (2*i +1 > n 无右孩子)。

 4、二叉树的存储结构

(1)顺序存储结构 

#define MAX 100
typedef int BT;
struct BiTree
{BT tree[MAX];int n;
};

 

(2)链式存储结构

// 二叉链树
typedef int TreeNodeType;
struct Bitree
{TreeNodeType data;struct Bitree* left, *right;
};
// 三叉链树
typedef int TreeNodeType;
struct Bitree
{TreeNodeType data;struct Bitree* left, * right;struct Bitree* parent;
};

5、二叉树的遍历 

(1)先序遍历

遍历的顺序是:根结点、左结点、右结点。

就比如上图的先序遍历是:A B D E C F 

void PreOrder(BiTree bt)
{//如果bt为空的话,就退出。if (bt == NULL)return;visit();//访问根节点PreOrder(bt->left);//先序遍历左子树,递归调用PreOrder(bt->right);//先序遍历右子树,递归调用
}

(2)中序遍历

遍历的顺序是:左结点、根节点、右结点。

上图的中序遍历是:D B E A F C

 

void InOrder(BiTree bt)
{//如果bt为空的话,就退出。if (bt == NULL)return;InOrder(bt->left);//中序遍历左子树,递归调用visit();//访问根节点InOrder(bt->right);//中序遍历右子树,递归调用
}

(3)后序遍历

遍历的顺序是:左结点、右结点、根节点。

上图的后序遍历是:D E B F C A

void PostOrder(BiTree bt)
{//如果bt为空的话,就退出。if (bt == NULL)return;PostOrder(bt->left);//中序遍历左子树,递归调用PostOrder(bt->right);//中序遍历右子树,递归调用visit();//访问根节点
}

(4)层序遍历

层序遍历的顺序:按二叉树从上到下,从左到右依次访问每个节点中存储的数据。 

上图的层序遍历是:A B C D E F

#define MAX 100
void LevelOrder(BiTree bt)
{if (bt == NULL)return;//队列BiTree Queue[MAX] = { 0 };int front = 0, rear = 0;//根节点入队Queue[rear] = bt;rear = (rear + 1) % MAX;while (rear != front){//访问队内第一个元素visit(Queue[front]);//如果队内第一个元素的左孩子不为空的话,入队if (Queue[front]->left != NULL){Queue[rear] = Queue[front]->left;rear = (rear + 1) % MAX;}//如果队内第一个元素的右孩子不为空的话,入队if (Queue[front]->right != NULL){Queue[rear] = Queue[front]->right;rear = (rear + 1) % MAX;}//队内第一个元素出队front = (front + 1) % MAX;}
}

6、求二叉树的高度(深度)

用递归的思想:将一个大问题转化为具有相同性质的小问题。 

二叉树的高度=max(左子树的高度,右子树的高度)

int BiTreeDepth(BiTree bt)
{if (bt == NULL){return 0;}int dl = 0, dr = 0, d = 0;dl = BiTreeDepth(bt->left);//求左子树的高度dr = BiTreeDepth(bt->right);//求右子树的高度d = dl > dr ? dl : dr;//求树的高度return d + 1;
}

7、求叶子结点的个数 

叶子节点的个数=左子树的叶子节点的个数+右子树的叶子节点的个数

int BiTreeLeaf(BiTree bt)
{//如果为空树,叶子结点为0if (bt == NULL)return 0;//判断是否是叶子结点if (bt->left == NULL && bt->right == NULL)return 1;//返回总数return (BiTreeLeaf(bt->left) + BiTreeLeaf(bt->right));
}

 8、根据先序序列和中序序列创建二叉树

 也可以根据后序序列和中序序列来进行创建二叉树

//根结点
BiTree bt = NULL;
BiTree PreInBiTreeCreate(int Pre[], int In[], int i, int j, int k, int h)
{//开辟空间bt = (BiTree)malloc(sizeof(struct BiTree));assert(bt);//将根结点的数据放入结构体中bt->data = Pre[i];bt->left = NULL;bt->right = NULL;int m = k;//找根结点的位置while (Pre[i] != In[m])m++;//如果m==k,bt没有左孩子if (m == k)bt->left = NULL;elsebt->left = PreInBiTreeCreate(Pre, In, i + 1, i + m - k, k, m - 1);//如果m==h,bt没有右孩子if (m == h)bt->right = NULL;elsebt->right = PreInBiTreeCreate(Pre, In, i + m - k + 1, j, m + 1, h);
}

 

谢谢大家的支持! 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/179360.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【hacker送书第3期】OpenCV轻松入门:面向Python(第2版)

第3期图书推荐 内容简介作者简介图书目录专家推荐参与方式 内容简介 本书基于面向 Python 的 OpenCV(OpenCV for Python),介绍了图像处理的方方面面。本书以 OpenCV 官方文档的知识脉络为主线,并对细节进行补充和说明。书中不仅介绍了 OpenCV 函数的使用…

Maven启动报错 - No goals have been specified for this build.You must specify a valid lifecycle phase

在对Maven项目进行Build / 初始化时 可能会出现下图这种情况&#xff1a; ​ [ERROR] No goals have been specified for this build. You must specify a valid lifecycle phase or a goal in the format <plugin-prefix>:<goal> or <plugin-group-id>:&l…

出纳常用的月报表,熬夜做了这8份直接用!

做出纳&#xff0c;公司财务的日报表是必不可少的&#xff0c;收支了多少&#xff0c;支出了多少&#xff0c;这些都是要记录下来的&#xff01; 一份出纳日报表通常包含以下内容&#xff1a; 1. 日期&#xff1a;报告涵盖的具体日期&#xff0c;标明是哪一天的财务数据。 2. 收…

如何使用企业微信 WorkTool API 开源框架快速开发企微聊天机器人(详细教程)

WorkTool 基本框架概述 WorkTool 是一个依附于企业微信来运行的无人值守群管理机器人程序&#xff0c;WorkTool 开源&#xff0c;并且永久免费。您可以使用本应用程序来自动执行一个自己企业微信里的账号&#xff08;当做机器人账号&#xff09;可通过后台调用对应的 API 来驱…

U-boot(六):命令体系,环境变量,iNand/SD卡驱动

本文主要探讨210的uboot命令体系&#xff0c;黄金变量,iNand/SD卡驱动相关知识。 命令体系 uboot命令体系 位置:uboot/common/ 参数:uboot命令支持传递参数(argc,argv) 函数:xxx命令的实现算数为do_xxx /** Use puts() inst…

基于mvc电影院售票预订选座系统php+vue+elementui

本影院售票系统主要包括二大功能模块&#xff0c;管理员功能模块和用户功能模块。 &#xff08;1&#xff09;管理员模块&#xff1a;系统中的核心用户管理员登录后&#xff0c;通过管理员功能来管理后台系统。主要功能有&#xff1a;首页、个人中心、电影类型管理、场次时间管…

数据结构 / day04 作业

1. 单链表任意位置删除, 单链表任意位置修改, 单链表任意位置查找, 单链表任意元素查找, 单链表任意元素修改, 单链表任意元素删除, 单链表逆置 // main.c#include "head.h"int main(int argc, const char *argv[]) {Linklist headNULL; //head 是头指针// printf(&q…

【Python 训练营】N_11 模拟进度条

题目 格式化输出进度条&#xff0c;具体格式如下&#xff1a; 分析 需要格式化打印&#xff0c;进度条随时间显示进展&#xff0c;需要用time模块的sleep()函数。 答案 import time # 导入time模块 length 100 # 定义进度长度模块 for i in range(1,length1): # 遍历1&…

96.STL-遍历算法 transform

目录 transform 语法&#xff1a; 功能描述&#xff1a; 函数原型&#xff1a; 代码示例&#xff1a; transform 是 C 标准模板库&#xff08;STL&#xff09;中的一个算法&#xff0c;用于对一个范围内的元素进行转换并将结果存储到另一个范围。以下是简要解释和一个示例…

AIGC系列之:Vision Transformer原理及论文解读

目录 相关资料 模型概述 Patch to Token Embedding Token Embedding Position Embedding ViT总结 相关资料 论文链接&#xff1a;https://arxiv.org/pdf/2010.11929.pdf 论文源码&#xff1a;https://github.com/google-research/vision_transformer PyTorch实现代码…

Nacos 端口偏移量说明

因为安全原因&#xff0c;在部署nacos-2.2.3版本时&#xff0c;将nacos的application.properties中的server.port端口值由默认值8848改成了server.port8425 问题&#xff1a;nacos 启动时(sh start.sh -m standalone)报错 如下&#xff1a; 经过分析&#xff0c;原因是 9425 …

深信服防火墙设置应用控制策略(菜鸟必看)

PS&#xff1a;前几天发布了关于深信服防火墙路由部署的流程&#xff1a;深信服防火墙路由模式开局部署-手把手教学&#xff08;小白篇&#xff09;-CSDN博客 昨天晚上有csdn的朋友联系我&#xff0c;说有一个关于ACL访问的问题要帮忙看一下 解决了以后&#xff0c;写个大概的…

Python变量及其使用

无论使用什么语言编程&#xff0c;总要处理数据&#xff0c;处理数据就需要使用变量来保存数据。 形象地看&#xff0c;变量就像一个个小容器&#xff0c;用于“盛装”程序中的数据。常量同样也用于“盛装”程序中的数据。常量与变量的区别是&#xff1a;常量一旦保存某个数据…

Android开源框架--Dagger2详解

功名只向马上取&#xff0c;真是英雄一丈夫 一&#xff0c;定义 我们知道在一个类中&#xff0c;通常会定义其他类型的变量&#xff0c;这个变量就是我们所说的“依赖“。 对一个类的变量进行初始化&#xff0c;有两种方式。第一种&#xff0c;这个类自己进行初始化&#xff…

4.Spring源码解析-loadBeanDefinitions(XmlBeanDefinitionReader)

第一个点进去 发现是空 肯定走的第二个逻辑了 这里在这里已经给属性设置了值&#xff0c;所以肯定不是空能拿到。 1.ClassPathXmlApplicationContext 总结&#xff1a;该loadBeanDefinitions是XmlBeanDefinitionReader设置xml文件在哪。

M3VSNET:无监督多度量多视图立体视觉网络(2021年)

M3VSNET&#xff1a;无监督多度量多视图立体视觉网络&#xff08;2021年&#xff09; 摘要1 引言2 相关工作3 实现方法3.1 网络架构 B. Huang, H. Yi, C. Huang, Y. He, J. Liu and X. Liu, “M3VSNET: Unsupervised Multi-Metric Multi-View Stereo Network,” 2021 IEEE Inte…

轻巧高效的剃须好工具,DOCO黑刃电动剃须刀上手

剃须刀大家都用过&#xff0c;我比较喜欢电动剃须刀&#xff0c;尤其是多刀头的悬浮剃须刀&#xff0c;感觉用起来很方便&#xff0c;剃须效率也很高。最近我在用一款DOCO小蔻的黑刃电动剃须刀&#xff0c;这款剃须刀轻巧易用&#xff0c;而且性价比超高。 相比于同类产品&…

Keil5 debug

目录 debug调试功能 基本功能&#xff1a; 程序复位&#xff1a;Reset 运行&#xff1a;Run 停止&#xff1a;Stop 断点调试&#xff08;Breakpoint Debugging&#xff09; 单步调试&#xff1a; 单步调试:Step 单步跳过调试&#xff1a;Step Over&#xff1a; 单步返…

Nginx-进程

Nginx-相关问题_01 Windows关闭所有nginx服务 windows 系统下开发调试时不用每次频繁的 启动->任务管理器->查找进程->结束进程&#xff01; 查看nginx的进程占用情况 tasklist | find /i "nginx.exe" || exit关闭nginx的所有进程 taskkill /im nginx.…

09. 智慧商城——订单结算、订单管理

01. 订单结算台 所谓的 “立即结算”&#xff0c;本质就是跳转到订单结算台&#xff0c;并且跳转的同时&#xff0c;需要携带上对应的订单参数。 而具体需要哪些参数&#xff0c;就需要基于 【订单结算台】 的需求来定。 (1) 静态布局 准备静态页面 <template><di…