嵌入式学习第三十三天!(二叉树)

1. 树的概念:

    1. 树:由n个结点组成的有限集,有且只有一个根结点(由根结点可以访问后继结点),其他结点只有一个前驱结点,但可以有多个后继结点(一对多)。当n = 0时,为空树。

    2. 叶子结点(终端结点):只有前驱结点没有后继结点;非叶子结点,即为分支结点。

    3. 度:子结点的个数称之为度。

    4. 树的度:树中各节点度的最大值。(默认为广度

    5. 深度:从根结点到最底层结点的层数。

    6. 森林:n个互不相交的树的集合。

2. 二叉树的概念:

    1. 二叉树:

        任意一个结点的子结点个数不能超过2个(树的度为2),且子节点的位置不可更改(一旦改变位置,就是两个不一样的二叉树)。

    2.  满二叉树:

        在不增加树的层数的前提下,无法再增加一个结点的二叉树。(叶子结点处在同一层,除了叶子结点以外,其余所有的结点的度都为2)

        特性:满二叉树第k层有2^(k-1)个结点,k层满二叉树总共有2^k-1个结点。

        练习:总结点为4847,求叶子结点为多少?

            首先:2^12 - 1 = 4096 - 1 = 4095, 即可以推断出有13层,即4847 - 4095 = 752个

            但第12层有:2^11 = 2048个,非叶子结点有752 / 2 = 376个

            所以叶子结点:2048 - 376 + 752 = 2424个

    3. 完全二叉树:

        只是删除了满二叉树最底层最右边的连续若干个结点,形成了完全二叉树。

        注意:1. 满二叉树是完全二叉树,但完全二叉树不一定是满二叉树。

                   2. 在满二叉树的基础上,如果要增加结点只能从上至下,从左至右的增加结点;如果要减少结点,只能从下至上,从右至左的删除结点。

3. 二叉树的遍历:

    主要研究一对多的树形结构存储到一对一的线性存储单元中:

    1. 前序遍历:先遍历根节点,再遍历左子树,最后遍历右子树(上图ABCEDFG)

    2. 中序遍历:先遍历左子树,再遍历根节点,最后遍历右子树(上图CBEAFDG)

    3. 后序遍历:先遍历左子树,在遍历右子树,最后遍历根节点(上图CEBFGDA)

    4. 层序遍历:从上至下,从左至右,依次遍历(上图ABDCEFG)

        注意:上诉前三种遍历方法为深度优化算法,第四种遍历方法为广度优先算法。

    练习:

        1. 如果只知道一个二叉树的前序遍历为ABC,求二叉树可能的情况:

        2. 如果知道一个二叉树的前序遍历为ABC,后序遍历为CBA,求二叉树可能的情况:

       3. 知道一个二叉树的前序遍历ABCEHDFG,中序遍历CBHEAFDG,求二叉树可能的情况:

        4. 知道一个二叉树的中序遍历CBHEAFDG,后续遍历CHEBFGDA,求二叉树可能的情况:

        从以上练习我们可以知道二叉树的遍历特性:如果只知道一个二叉树的前序遍历不能还原唯一的二叉树,知道前序遍历+后序遍历也不行,必须知道前序遍历+中序遍历,或者后序遍历+中序遍历才能得到唯一确定的一颗二叉树。

4. 二叉树的实现:

    1. 二叉树的定义:

typedef char BTDATA_TYPE;typedef struct tree_node
{BTDATA_TYPE data;struct tree_node *pl;struct tree_node *pr;
}TREE_NODE;

    2. 二叉树的创建:

int idx = 0;
int cnt = 0;
char tree[] = {"ABC##EH###DF##G##"};TREE_NODE *Create_BTree(void)
{BTDATA_TYPE data = tree[idx++];if(data == '#'){return NULL;}TREE_NODE *pnode = malloc(sizeof(TREE_NODE));if(pnode == NULL){perror("fail to malloc");return NULL;}pnode->data = data;pnode->pl = Create_BTree();pnode->pr = Create_BTree();return pnode;
}

    3. 二叉树的前序遍历:

void Pre_Order(TREE_NODE *proot)
{if(proot == NULL){return;}printf("%c", proot->data);Pre_Order(proot->pl);Pre_Order(proot->pr);
}

    4. 二叉树的中序遍历:

void Mid_Order(TREE_NODE *proot)
{if(proot == NULL){return;}Mid_Order(proot->pl);printf("%c", proot->data);Mid_Order(proot->pr);
}

    5. 二叉树的后序遍历:

void Pos_Order(TREE_NODE *proot)
{if(proot == NULL){return;}Pos_Order(proot->pl);Pos_Order(proot->pr);printf("%c", proot->data);
}

    6. 二叉树的层序遍历(结合前一篇的队列实现):

void Link_Layer_Order(TREE_NODE *proot)
{QUEUE_LIST *pque = Create_Queue_List();if(pque == NULL){printf("fail to create queue list\n");return;}QUEUE_NODE *pnode = Create_Queue_Node(proot);if(pnode == NULL){printf("fail to create queue node\n");return;}DATA_TYPE outdata;Push_Queue_Link(pque, pnode);while(!Is_Empty_Queue(pque)){Pop_Queue_Link(pque, &outdata);printf("%c", outdata->data);if(outdata->pl != NULL){pnode = Create_Queue_Node(outdata->pl);Push_Queue_Link(pque, pnode);}if(outdata->pr != NULL){pnode = Create_Queue_Node(outdata->pr);Push_Queue_Link(pque, pnode);}}Destory_Queue(pque);return;
}

    7. 获得二叉树的结点个数:

int Get_PTree_Node_Cnt(TREE_NODE *proot)
{if(proot == NULL){return 0;}return 1+Get_PTree_Node_Cnt(proot->pl) + Get_PTree_Node_Cnt(proot->pr);
}

    8. 获得二叉树的层数:

int Get_PTree_Layer_Cnt(TREE_NODE *proot)
{if(proot == NULL){return 0;}int layl = Get_PTree_Layer_Cnt(proot->pl);int layr = Get_PTree_Layer_Cnt(proot->pr);return layl > layr ? layl+1 : layr+1;
}

    9. 销毁二叉树:

void Destroy_PTree(TREE_NODE *proot)
{if(proot == NULL){return;}Destroy_PTree(proot->pl);Destroy_PTree(proot->pr);free(proot);
}

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

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

相关文章

OpenAI 刚刚宣布了 “GPT-4o“ 免费用户开放、通过 API 可用

OpenAI 刚刚宣布了 “GPT-4o”。它可以通过语音、视觉和文本进行推理。 该模型速度提高了 2 倍,价格降低了 50%,比 GPT-4 Turbo 的速率限制高出了 5 倍。 它将对免费用户开放、通过 API 可用。 与 GPT-4 相比,GPT-4o 的速度和额外的编码能力…

揭秘APP广告:变现逻辑全解析!

在当今的移动互联网时代,APP广告变现已经成为了各大应用开发者的主要营收来源之一。然而,随着科技的发展、用户行为的变化以及广告市场趋势的演进,APP广告变现逻辑也正在不断地进行优化和调整。本文将基于当前市场和技术趋势,为大…

Proteus新手入门之初学体验

Proteus是嵌入式工程师比较喜欢用的,可以实现从原理图布图、代码调试到单片机与外围电路协同仿真。作为一款功能强大的电子电路仿真软件,Proteus为电子爱好者和工程师们提供了一个理想的平台,用于设计、测试和验证各种电子电路。对于初学者来…

CSS 块状元素

还是大剑师兰特:曾是美国某知名大学计算机专业研究生,现为航空航海领域高级前端工程师;CSDN知名博主,GIS领域优质创作者,深耕openlayers、leaflet、mapbox、cesium,canvas,webgl,ech…

Saas详解

1. 什么是Saas SaaS(Software-as-a-Service),简单点理解就是软件即服务,即通过网络提供软件服务。 在SaaS模型中,用户不需要在本地安装软件,而是通过网络(通常是浏览器)访问应用程…

LeetCode算法题:49. 字母异位词分组(Java)

给你一个字符串数组,请你将 字母异位词 组合在一起。可以按任意顺序返回结果列表。 字母异位词 是由重新排列源单词的所有字母得到的一个新单词。 示例 1: 输入: strs ["eat", "tea", "tan", "ate", "nat", …

答辩PPT自述稿如何准备?笔灵AI答辩PPT,自动生成演讲稿

很多快要毕业的同学在做答辩PPT的时候总是感觉毫无思路,一窍不通。但这并不是你们的错,对于平时没接触过相关方面,第一次搞答辩PPT的人来说,这是很正常的一件事。一个好的答辩PPT可以根据以下分为以下几部分来写。 1.研究的背景和…

试试这四个AI论文工具和降重技术,低成本高回报

在科研领域,AI写作工具如同新一代的科研利器,它们能够极大提高文献查阅、思路整理和表达优化的效率,本质上促进了科研工作的进步。AI写作工具不仅快速获取并整理海量信息,还帮助我们精确提炼中心思想,显著提升论文写作…

研发管理-选择研发管理系统-研发管理系统哪个好

选择研发管理系统-研发管理系统哪个好 选择研发管理系统时,并没有一个绝对的“最好”的系统,因为每个企业的需求和情况都是独特的。然而,我可以向您介绍一些在市场上广受欢迎且功能强大的研发管理系统,供您参考: 1、彩…

MathType7.9中文官方最新破解汉化版无需许可证激活码

MathType是一个功能强大的数学公式编辑器,它能够帮助用户轻松地创建、编辑和排版各种数学公式。无论是学生、教师还是科研人员,都可以从MathType的丰富功能中受益。本文将为您详细介绍MathType的主要功能和使用方法,帮助您更好地利用这个工具…

web网页录音(recorder.js)并上传后端语音转文字(Vosk)

我是一个后端开发人员,现在都快进化成全栈了。操了,是谁有好的项目让我跳跳槽,转转行吧 写在前面,很重要 这是官方文档的说明 翻译如下: 我们有两种型号-大型号和小型号,小型号非常适合在移动应用程序上执…

远程服务器AutoDL登录/配环境/部署运行大模型方法

1. AutoDL autodl平台,是一个功能强大的本地大语言模型LLM运行专家,为用户提供了简单高效的方式来运行大型语言模型.通过优化设置和配置细节。 地址:AutoDL官方地址 2. 登录远程服务器方式 登录远程服务器的方式和工具有很多种 2.1 方法一 用AutoDL…

应用层(上篇)

应用层 应用层协议原理 网络应用程序体系解构 应用程序体系结构: 由应用程序研发者设计规定了如何在各种端系统上组织该应用程序。在选择应用程序体系结构时,应用程序研发者很可能利用现代网络应用程序中所使用的两种主流体系结构之一:客户-服务器体系结构或对等…

24.5.12(23广东,19陕西)(字典树)

星期一: dp题单 区间dp第三题 二叉搜索树 cf传送门 思路:dp【i】【j】【0/1】表示区间 i到 j,以 i / j为根节点能否形成一棵二叉搜索树 因为题目要求组成二叉搜索树,若 i 到 j 的节点为一颗完整的子…

等保2.0的全面解读与实施策略

《网络安全等级保护基本要求》(等保2.0)是中华人民共和国国家安全部于2019年6月发布的网络安全等级保护标准。该标准规定了我国关键信息基础设施的网络安全等级保护要求和评估标准,对于保障我国网络安全具有重要的意义。下面是对等保2.0的全面…

Scratch四级:第09讲 搜索算法

第09讲 搜索算法 教练:老马的程序人生 微信:ProgrammingAssistant 博客:https://lsgogroup.blog.csdn.net/ 讲课目录 常考的搜索算法项目制作:“小猫钓鱼”项目制作:“统计身高”项目制作:“找出出现次数最多的数字”搜索算法 搜索算法常用于列表的题目中,包括: (1)…

LabVIEW开发RS422通信

LabVIEW开发RS422通信 项目围绕LabVIEW软件开发的程序在RS422通信技术检测方面的应用进行展开,通过软件编程将上位计算机虚拟化为检测设备,控制其通信端口与被测产品进行RS422通信,以此检验产品的性能优劣。该虚拟检测仪器在实际测试中表现出…

c++红黑树的模拟实现

目录 1. 红黑树的概念 ​编辑 2. 红黑树的性质 3. 红黑树的模拟实现 3.1 红黑树节点的定义 3.2 红黑树的插入 旋转代码 插入主逻辑代码 验证是否平衡 4. 红黑树与AVL树的比较 1. 红黑树的概念 红黑树,是一种二叉搜索树,但在每个结点上增加一…

嵌入式中STM32上模拟启动Linux自动初始化

Linux中有很多编程思想可以学习,很多大佬把这些思想、机制运用到单片机的编程上。 下文,在STM32上模拟Linux kernel自动初始化流程。 通常我们写程序都是按照这个套路,一个函数一个函数按照顺序逻辑一个一个的执行下去。 如果逻辑非常复杂,涉及的模块比较多,那么这种顺…

Quests system for Unity

一个简单而灵活的任务系统将帮助你实现所有的想法,而不需要事件和逻辑中的一堆额外代码! 我的资产是一个用于执行任务的独立系统。 特征: 任务逻辑不需要继承MonoBehaviour。 在一行中完成所需任务的激活/进度/完成。 易于理解的界面,包含项目中所有任务的列表。 不需要连接…