二叉树理论和题目

news/2025/2/10 13:41:37/

二叉树的种类

在我们解题过程中二叉树有两种主要的形:满二叉树和完全二叉树。

满二叉树

满二叉树:如果一棵二叉树只有度为0的结点和度为 2 的结点,并且度为 0 的结点在同一层上,则这棵二叉树为满二叉树。

这棵二叉树为满二叉树,也可以说深度为 k,有2^k-1个节点的二叉树。

完全二叉树

完全二叉树的定义如下:在完全二叉树中,除了最底层节点可能没填满外,其余每层节点数都达到最大值,并且最下面一层的节点都集中在该层最左边的若干位置。若最底层为第h层(h从1开始),则该层包含1~ 2^(h-1)个节点。

二叉搜索树

前⾯介绍的树,都没有数值的,而二叉搜索树是有数值的了,二叉搜索树是⼀个有序树。

若它的左子树不空,则左子树上所有结点的值均小于它的根结点的值;

若它的右子树不空,则右子树上所有结点的值均大于它的根结点的值;

它的左、右子树也分别为二叉排序树

二叉树的存储方式

链式存储

顺序存储

如果父节点的数组下标是 i,那么它的左孩子就是 i * 2 + 1,右孩⼦就是 i * 2 + 2。

二叉树的遍历方式

二叉树的递归顺序

二叉树的迭代遍历

前序遍历

前序遍历是中左右,每次先处理的是中间节点,那么先将根节点放入栈中,然后将右孩子加入栈,再加入左孩子。

为什么要先加入右孩子,再加入左孩子呢?因为这样出栈的时候才是中左右的顺序。

中序遍历

分析一下为什么刚刚写的前序遍历的代码,不能和中序遍历通用呢,因为前序遍历的顺序是中左右,先访问的元素是中间节点,要处理的元素也是中间节点,所以刚刚才能写出相对简洁的代码,因为要访问的元素和要处理的元素顺序是一致的,都是中间节点。

那么再看看中序遍历,中序遍历是左中右,先访问的是二叉树顶部的节点,然后一层一层向下访问,直到到达树左面的最底部,再开始处理节点(也就是在把节点的数值放进result数组中),这就造成了处理顺序和访问顺序是不一致的。

那么在使用迭代法写中序遍历,就需要借用指针的遍历来帮助访问节点,栈则用来处理节点上的元素。

后序遍历

叉树层序遍历

需要借用一个辅助数据结构即队列来实现,队列先进先出,符合一层一层遍历的逻辑,而用栈先进后出适合模拟深度优先遍历也就是递归的逻辑。

题目一

这是二叉搜索树吗?

代码:

# include <stdio.h>struct node
{int val;struct node * left;struct node * right;
};int n;
int num[1000];int treemade(int l, int r, struct node* root)//二叉搜索树
{if (l > r)return 1;int stand = num[l];int help = l + 1;while (help < r && num[help] < stand)help++;int mid = help;while (help < r && num[help] >= stand)help++;if (help < r )//若大与小与部分拼不成一个完整序列,则说明不符合return 0;root = (struct node*) malloc(sizeof(struct node));root->val = num[l];root->left = NULL;root->right = NULL;return (treemade(l+1, mid-1, root->left) && treemade(mid, r, root->right));}void cmp(struct node* root, int cnt)
{if (root->left != NULL)cmp(root->left, cnt+1);if (root->right != NULL);cmp(root->right, cnt+1);if (cnt == 0)  //特判printf("%d", root->val);elseprintf("%d ", root->val);
}int main()
{scanf("%d", &n);for (int i=0; i<n; ++i)scanf("%d");struct node* root;root = NULL;if (treemade(0, n, root));//判断能否建成二叉搜索树{printf("YES\n");cmp(root);}}

题目二

解题

在后序遍历序列中,根节点总是在最后一个位置,而在中序遍历序列中,根节点将序列分为左右两部分,分别对应左子树和右子树。

因此,我们可以利用两个数组的信息,递归构建二叉树,然后再进行层序遍历。

# include <stdio.h>
int n;
int num1[31];
int num2[31];struct node
{int val;struct node* left;struct node* right;
};void treemade(int l, int r, struct node* root, int k)
{int flag = 0;if (k < 0)return;int help = num1[k];int mid;for (int i=l; i<=r; ++i){if (num[i] == help){mid = i;flag = 1;break;}}if (flag == 1){root = (struct node*)malloc(sizeof(struct node));root->val = help;root->left = NULL;root->right = NULL;	treemade(l, mid-1, root->left, k-1);treemade(mid+1, r, root->right, k-1);}else{treemade(l, r, root, k-1);}
}int main()
{scanf("%d", &n);for (int i=0; i<n; ++i)scanf("%d", &num1[i]);for (int i=0; i<n; ++i)scanf("%d", &num2[i]);int k = n-1;struct node* root = NULL;}


http://www.ppmy.cn/news/1443156.html

相关文章

基于 dockerfile 编写LNMP

目录 一. 环境准备 二. 部署 nginx 2.1 建立工作目录&#xff0c;并上传需要的安装包 2.2 配置 nginx.conf 文件 2.3 编写 dockerfile 2.4 构建一个新的镜像 2.5 启动一个新的容器 三. 部署MySQL 3.1 建立工作目录&#xff0c;并上传安装包 3.2 编写 Dockerfile 3.…

AIGC技术:引领内容创作革命,塑造未来媒体与娱乐产业

如何看待AIGC技术&#xff1f; AIGC技术&#xff08;人工智能生成内容&#xff09;是人工智能领域的最新进展&#xff0c;是创新的“第三步”。但人工智能的发展是连续的&#xff0c;包括多个阶段和技术突破。其发展可分为&#xff1a;1. 基础理论建立&#xff0c;涉及计算机科…

FreeRTOS之列表

1.FreeRTOS的列表和列表项十分重要。列表类相当于链表&#xff0c;列表项则相当于链表中的节点。列表项的地址是非连续的&#xff0c;列表项的数量可随时修改。在OS中的任务状态和数量会发生改变&#xff0c;因此使用列表可以很好的满足需求。 列表和列表项的相关定义与操作函…

CMUS狮身人面像(四)-构建语言模型

构建语言模型 语言模型是配置的重要组成部分&#xff0c;它告诉解码器可以识别哪些单词序列。 模型有多种类型&#xff1a;关键词列表、语法和统计语言模型以及语音语言模型。它们具有不同的功能和性能特性。您可以根据需要选择任何解码模式&#xff0c;甚至可以在运行时在模…

从Grafana支持的认证方式分析比较IAM产品现状与未来展望

调研报告 标题&#xff1a;从Grafana支持的认证方式分析比较IAM产品现状与未来展望 概述 本报告首先概述了评价IAM&#xff08;Identity and Access Management&#xff09;产品的主要因素&#xff0c;并基于Grafana支持的认证方式&#xff0c;引出对IAM产品的深入探讨。通过…

Flink DataStream API 批处理能力演进之路

摘要&#xff1a;本文由阿里云 Flink 团队郭伟杰老师撰写&#xff0c;旨在向 Flink Batch 社区用户介绍 Flink DataStream API 批处理能力的演进之路。内容主要分为以下三个部分&#xff1a; 1. 批处理语义和性能优化 2. Batch API 功能增强 3. 总结 最近在和一个朋友闲聊时&am…

秋招后端开发面试题 - Java语言基础(下)

目录 Java基础下前言面试题toString() 、String.valueof()、(String)&#xff1f;hashCode() 方法&#xff1f;hashCode 和 equals 方法判断两个对象是否相等&#xff1f;为什么重写 equals 时必须重写 hashCode 方法&#xff1f;String、StringBuffer、StringBuilder?String …

【保姆级讲解下gateway基本配置】

&#x1f3a5;博主&#xff1a;程序员不想YY啊 &#x1f4ab;CSDN优质创作者&#xff0c;CSDN实力新星&#xff0c;CSDN博客专家 &#x1f917;点赞&#x1f388;收藏⭐再看&#x1f4ab;养成习惯 ✨希望本文对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出…