【初阶数据结构篇】实现链式结构二叉树(二叉链)下篇

news2025/1/14 18:43:09

文章目录

  • 实现链式结构二叉树(二叉链)下篇
    • 前言
    • 二叉树实现方法
      • 二叉树查找值为x的结点
      • 二叉树的销毁
      • 二叉树的层序遍历
      • 判断是否为完全二叉树
    • 二叉树性质选择题
    • 二叉树遍历选择题

实现链式结构二叉树(二叉链)下篇

前言

接上一篇

实现链式结构二叉树(二叉链)上篇

二叉树实现方法

二叉树查找值为x的结点

  • 分为左右子树查找,依次递推即可
  • 结束条件为空:说明在这一路径上没有找到
  • 结束条件找到了返回结点指针即可
BTNode* BinaryTreeFind(BTNode* root, BTDataType x)
{
	if (root == NULL)
	{
		return NULL;
	}
	if (root->data == x)
	{
		return root;
	}

	BTNode* leftFind = BinaryTreeFind(root->left, x);
	if (leftFind)
	{
		return leftFind;
	}
	BTNode* rightFind = BinaryTreeFind(root->right, x);
	if (rightFind)
	{
		return rightFind;
	}
	return NULL;
}

二叉树的销毁

  • 注意这里我们要改变root指针的指向,将本来指向根节点的root指针改为空,所以传二级指针(一级指针也可以,只不过在调用完记得把root置为空)
  • 先销毁左右子树,最后销毁根节点
  • 当为空时,不用销毁直接返回
void BinaryTreeDestory(BTNode** root)
{
	if (*root == NULL)
	{
		return;
	}
	BinaryTreeDestory(&((*root)->left));
	BinaryTreeDestory(&((*root)->right));

	free(*root);
	*root = NULL;
}

二叉树的层序遍历

除了先序遍历、中序遍历、后序遍历外,还可以对⼆叉树进⾏层序遍历。设⼆叉树的根结点所在层数为1,层序遍历就是从所在⼆叉树的根结点出发,⾸先访问第⼀层的树根结点,然后从左到右访问第2层的结点,接着是第三层的结点,以此类推,⾃上⽽下,⾃左⾄右逐层访问树的结点的过程就是层序遍历

由于递归会沿着一边路径一直递归下去,所以显然不能使用递归!

  • 实现层序遍历需要额外借助数据结构:队列

1722303194814)

  • 创建并初始化队列,注意将队列结点存储的数据类型更改
  • 这里我们插入的是指向结点的指针,而不是结点的值,否则找不到结点的左右孩子,所以队列结点存储的数据类型为struct BTNode*
  • 首先将指向根节点的指针入队列,保存后并打印结点的值
  • 根节点出队列,保证每一次取到的队列的头都是新的
  • 如果根节点左右孩子不为空就将其入队列,为空则无必要,不需要打印NULL
  • 重复上述操作直到队列为空
//层序遍历
//借助数据结构---队列
void LevelOrder(BTNode* root)
{
	Queue q;
	QueueInit(&q);
	QueuePush(&q, root);
	while (!QueueEmpty(&q))
	{
		//取队头,打印
		BTNode* front = QueueFront(&q);
		printf("%d ", front->data);
		QueuePop(&q);
		//队头节点的左右孩子入队列
		if (front->left)
			QueuePush(&q, front->left);
		if (front->right)
			QueuePush(&q, front->right);
	}
	//队列为空
	QueueDestroy(&q);
}

判断是否为完全二叉树

pA8G4-1722303194815)

  • 同样使用层序遍历
  • 左右结点不管是否为空,都入队列
  • 第一个循环用来取二叉树第一个NULL结点前的所有数据
    • 如果是完全二叉树,跳出此循环后剩下的都是NULL结点
    • 如果是非完全二叉树,跳出此循环后还有非空结点
  • 于是第二个循环用来判断此时队列里是否有非空的指针
    • 如果直到队列为空跳出循环说明全是空指针,返回true
    • 反之返回false
//判断二叉树是否为完全二叉树
//---队列
bool BinaryTreeComplete(BTNode* root)
{
	Queue q;
	QueueInit(&q);
	QueuePush(&q, root);
	while (!QueueEmpty(&q))
	{
		BTNode* front = QueueFront(&q);
		QueuePop(&q);
		if (front == NULL)
		{
			break;
		}
		QueuePush(&q, front->left);
		QueuePush(&q, front->right);
	}
	//队列不一定为空
	while (!QueueEmpty(&q))
	{
		BTNode* front = QueueFront(&q);
		QueuePop(&q);
		if (front != NULL)
		{
			QueueDestroy(&q);
			return false;
		}
	}
	QueueDestroy(&q);
	return true;
}

二叉树性质选择题

  • 在二叉树基础概念这篇博客中讲到了二叉树叶子结点个数==度为2结点个数+1
  • 本题选B

在这里插入图片描述

  • 由二叉树的定义可知,树中必定存在度为0的结点和度为2的结点,设度为0结点有a个,根据度为0的结点(即叶子结点)总比度为2的结点多一个,得度为2的结点有a一1个。

  • 再根据完全二叉树的定义,度为1的结点有0个或1个

  • 假设度1结点为0个,a+0+a一1=2n,得2a=2n一1,由于结点个数必须为整数,假设不成立;

  • 当度为1的结点为1个时,a+1+a一1=2n,得a=n,即叶子结点个数为n。

  • 本题选A


在这里插入图片描述

  • 由29-1<531<210-1
  • 说明第九层填满,第十层没有填满
  • 本题选B

在这里插入图片描述

  • 与第二题同理
  • 由二叉树的定义可知,树中必定存在度为0的结点和度为2的结点,设度为0结点有a个,根据度为0的结点(即叶子结点)总比度为2的结点多一个,得度为2的结点有a一1个。
  • 再根据完全二叉树的定义,度为1的结点有0个或1个
  • 假设度1结点为0个,a+0+a一1=767,得2a=768,即叶子结点个数为384
  • 当度为1的结点为1个时,a+1+a一1=767,不为整数,舍去。
  • 本题选B

二叉树遍历选择题

在这里插入图片描述

  • 根据层序遍历
  • 从上到下,从左到右可以直接画出二叉树结构
    -在这里插入图片描述
  • 根据前序遍历规则即可
  • 本题选A

在这里插入图片描述

  • 认真审题!先序遍历确定根节点
  • 本题选A

在这里插入图片描述

  • 后序遍历最后一个一定是根节点
  • 中序遍历中得到根节点左右子树
  • 确定一个划去一个
  • 在左右子树又可以根据后序遍历确定根节点
  • 再看中序遍历得到左右子树
  • 重复上述操作即可画出二叉树

在这里插入图片描述
本题选D


在这里插入图片描述

  • 思路和第三题一样

在这里插入图片描述

本题选A

以上就是实现链式结构二叉树(二叉链)下篇的内容啦,各位大佬有什么问题欢迎在评论区指正,您的支持是我创作的最大动力!❤️
请添加图片描述

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

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

相关文章

一文弄懂北斗RTK差分​高精度定位技术原理

北斗RTK差分定位技术是一种高精度定位技术&#xff0c;它的原理基于北斗卫星导航系统。北斗RTK差分定位技术需要三个接收器&#xff1a;基站接收器、移动接收器和校正接收器。基站接收器从北斗导航卫星系统接收信号&#xff0c;并将这些信号传输到校正接收器。移动接收器接收来…

【AI大模型】-- 应用部署

一、GPU价格参考 有些在京东就能买到&#xff1a;https://item.jd.com/10065826100148.html美国商务部限制 GPU 对华出口的算力不超过 4800 TOPS 和带宽不超过 600 GB/s&#xff0c;导致最强的 H100 和 A100 禁售。英伟达随后推出针对中国市场的 A800 和 H800。 H100 与 A100&…

打造重庆市数字化教育“新名片”,广阳湾珊瑚中学凭实力“出圈”!

分布于教学楼连廊顶部的智能照明设备,根据不同的时间和场景需求自动调节灯光亮度和开关状态;安装于各个教室内的智能黑板、学校同步时钟、学生互动设备,在极简以太全光网的赋能下,为师生提供丰富的教学体验与学习支持......行走于重庆市广阳湾珊瑚中学,像是与充满科技感的“校园…

开源数据结构存储系统Redis的内部数据结构详解(下)

目录 1、整数集合 1.1、整数集合的定义 1.2、升级 1.3、降级 2、压缩列表 2.1、压缩列表定义 2.2、压缩列表节点 2.3、压缩列表对象 3、总结 C++软件异常排查从入门到精通系列教程(专栏文章列表,欢迎订阅,持续更新...)https://blog.csdn.net/chenlycly/article/de…

【大数据】虚拟机前置准备

前言&#xff1a; 我们了解了大数据Hadoop是分布式体系。 所以&#xff0c; 为了能确保正常部署好大数据的集群&#xff0c;我们需要做好提前的准备&#xff1a; 准备多台Linux虚拟机 准备基础的Linux操作环境&#xff08;SSH免密、防火墙、JDK等&#xff09; 配置多台Linux…

testRigor-基于人工智能驱动的无代码自动化测试平台

1、testRigor介绍 简单来说&#xff0c;testRigor是一款基于人工智能驱动的无代码自动化测试平台&#xff0c;它能够通过分析应用的行为模式&#xff0c;智能地生成测试用例&#xff0c;并自动执行这些测试&#xff0c;无需人工编写测试脚本。可以用于Web、移动、API和本机桌面…

MongoDB 基础知识

一、为什么学习MongoDB MongoDB解决Mysql 的“三高”问题&#xff1a; 1.对数据库高并发写入需求 2.对海量数据高效率存储访问需求 3.对数据库高扩展和高可用的需求 MongoDB 实际应用&#xff1a; 1.社交场景&#xff0c;比如朋友圈&#xff0c;附近的人的地点的存储 2.…

常用七大公司加密软件排行榜|2024年好用高效加密软件最新推荐

加密软件对于保护公司数据和确保信息安全至关重要。本文分享七款公司加密软件&#xff0c;每款软件的功能和优势都有所不同&#xff0c;可以根据企业的具体需求选择合适的解决方案。 1. 固信软件 功能&#xff1a; 固信软件提供全面的数据保护解决方案&#xff0c;透明加密、智…

Java开发者LLM实战——使用LangChain4j构建本地RAG系统

1、引言 由于目前比较火的chatGPT是预训练模型&#xff0c;而训练一个大模型是需要较长时间&#xff08;参数越多学习时间越长&#xff0c;保守估计一般是几个月&#xff0c;不差钱的可以多用点GPU缩短这个时间&#xff09;&#xff0c;这就导致了它所学习的知识不会是最新的&…

Stable Diffusion参数 - 步数、采样方法、提示词引导系数

1 迭代步数 一张图片的生成它需要多次迭代才能达到我们想要的一个效果。 理论上迭代步数越高&#xff0c;那生成的最终的这个图片的效果就越好&#xff0c;它质量更高。 实际在应用的时候迭代步数达到20以上&#xff0c;它的效果在提升的就不是十分明显了&#xff0c;而更多的…

基于python的百度迁徙迁入、迁出数据分析(三)

百度迁徙定义 百度迁徙释义&#xff1a; 百度迁徙以用户常住地所在地市或停留超过一天的非常住地定义为出发城市&#xff0c;以用户离开出发城市&#xff0c;并在非出发城市停留超过4 h以上定义为到达城市。采用4h阈值&#xff0c;排除了城际出行中的途经地。 定义参考来源…

当年很流行,现在已经淘汰的Java技术,请不要学了!【建议收藏】

在Java技术的发展历程中&#xff0c;确实有一些曾经流行但现在已经被淘汰或不再推荐使用的技术。了解这些技术可以帮助你避免学习过时的知识&#xff0c;从而更高效地提升自己的技能。 以下是一些曾经流行但现在已经不太推荐学习的Java技术&#xff1a; 1. Servlet 2.x&#x…

日程管理多源归一,服务场景一键直达

时间对于每个人来说都是非常宝贵的&#xff0c;曾经我们使用台历、挂历来标记和查看重要日程&#xff0c;通过翻页来见证时光的流逝&#xff0c;随着信息化时代的不断发展&#xff0c;更加灵活简洁的电子日历成为主流&#xff0c;日历也从一个最简单的日期看板&#xff0c;慢慢…

RuntimeError: No CUDA GPUs are available

RuntimeError: No CUDA GPUs are available 目录 RuntimeError: No CUDA GPUs are available 【常见模块错误】 【解决方案】 解决步骤如下&#xff1a; 欢迎来到英杰社区https://bbs.csdn.net/topics/617804998 欢迎来到我的主页&#xff0c;我是博主英杰&#xff0c;211科…

如何利用代理ip探索外国新闻视角?

引言 在日常的网络使用中我们常常会遇到诸多难题&#xff0c;让我们无法获取到想要的信息或服务&#xff0c;若访问速度很慢还会影响好的在线工作和娱乐体验。其次&#xff0c;随着网络安全问题的频发&#xff0c;个人隐私泄露成为了一个不容忽视的问题。这些痛点&#xff0c;…

React Native新架构系列-新架构介绍

从今天起&#xff0c;会陆续更新React Native新架构相关的系列内容&#xff0c;本系列基于React Native 0.73.4版本&#xff0c;从一名Android开发者的视角进行介绍。本系列介绍的内容默认读者对React Native有一定的了解&#xff0c;对基础的开发内容不再赘述。 前言 首先介绍…

AI绘画3分钟解决英文恐惧症,comfyui汉化插件

前言 全面解析&#xff1a;Comfy UI汉化插件的安装与配置指南 本文涉及的工作流和插件&#xff0c;需要的朋友请扫描免费获取哦 引言 本文图片来源网络&#xff0c;侵权联删除。 在全球化的今天&#xff0c;软件界面的本地化是提升用户体验的重要一环。对于许多非英语母语的…

辅听耳机芯片型号介绍—云信通讯

辅听耳机系列芯片介绍&#xff1a; 杰理芯片型号&#xff1a; AC7003D / AC7006F 芯片特点&#xff1a; 1.内置啸叫抑制算法 2.内置辅听专用动态多段增益调节 3.内置人声增强和环境噪声压制算法 4.公版手机app开放定制服务&#xff0c;支持听力测试和个性化增益配置 5.支…

WAAP替代传统WAF已成趋势

数字化时代&#xff0c;Web应用和API已成为企业运营的核心。然而&#xff0c;随着网络攻击手段的不断进化&#xff0c;自动化攻击愈发频繁&#xff0c;传统的Web应用防火墙&#xff08;WAF&#xff09;已难以满足现代企业的安全需求。WAAP&#xff08;Web Application and API …

Springboot手工艺品交易平台—计算机毕业设计源码11541

摘 要 信息化社会内需要与之针对性的信息获取途径&#xff0c;但是途径的扩展基本上为人们所努力的方向&#xff0c;由于站在的角度存在偏差&#xff0c;人们经常能够获得不同类型信息&#xff0c;这也是技术最为难以攻克的课题。针对手工艺品交易平台等问题&#xff0c;对手工…