树低级(C语言版)

一.树基本计算规则

关于树的大部分知识点我们都讲过了,那么如果我给你树的节点,你可以算出叶子节点个数吗?

下面我们总结下一些计算规则:

1.父子计算规则:

parent=(child-1)/2;

leftchild=parent*2+1,rightchild=parent*2+2;

2.若规定根节点的层数为1,则一棵非空二叉树的第i层上最多有2^(i-1)个节点

3.深度为h的二叉树的最大结点数是2^h-1;

4. 对任何一棵二叉树, 如果度为0其叶结点个数为N0 , 度为2的分支结点个数为N2 ,则有

N0=N2+1
5. 若规定根节点的层数为1,具有n个结点的满二叉树的深度,h=log(n+1)  (log以2 为底,n+1为对数)
例题一:
1. 某二叉树共有 399 个结点,其中有 199 个度为 2 的结点,则该二叉树中的叶子结点数为
A 不存在这样的二叉树
B 200
C 198
D 199
规则4,结果为200个,即B
如果不知道规则,那么就可能浪费不必要的时间,大家可以自行去找其他题目。

二.层序遍历

上次我们留下层序遍历没实现,现在我们学习树更近一步了,我们可以实现层序遍历了,在实现前让我们来看看下面两个概念:
深度优先遍历(Depth First Search):简称DFS,前序遍历,中序遍历和后序遍历都是,即一种 递归的遍历方式从一个起点开始,沿着一条路径一直走到底,直到不能再走为止,然后回溯到上一个节点,继续遍历其他路径,直到所有节点都被遍历过。
广度优先遍历(Breadth First Search):又称为广度优先搜索,简称BFS。是一种分层的查找过程,每向前走一步可能访问一批顶点,不像深度优先搜索那样有往回退的情况,因此它不是一个递归的算法。它是一个逐层遍历的过程,层序遍历就是BFS。
大家可能都经历过这样一个过程,就是使用QQ时,会推荐好友的好友,这其实就是一个广度优先遍历的实例。
下面回归我们主题:
如何去写层序遍历呢?
这个时候,是不是可以想到用队列,如果我们将树根放进队列,如果我们出队列,将树根的左右子序列放入,这样一直循环,是不是就可以做到层序遍历。
下面请看代码:
// 层序遍历定义(一:一起遍历)
void LevelOrder(TreeNode* root)
{
	Queue s1;
	QueueInit(&s1);
	//判断是否为空,不空的话,先压进一个
	if(root)
		QueuePush(&s1, root);
	while (!QueueEmpty(&s1))
	{
		TreeNode* cur = QueueFront(&s1);
		QueuePop(&s1);
		printf("%d ", cur->date);
		//压入它的左右孩子
		if(root->left)
			QueuePush(&s1, root->left);
		if (root->right)
			QueuePush(&s1, root->right);
	}
	printf("\n");
}

还是以这个树,我们检查一下:
//动态开辟空间定义
TreeNode* BuyTreeNode(int x)
{
	//开辟树的空间
	TreeNode* node = (TreeNode*)malloc(sizeof(TreeNode));
	assert(node);
	node->date = x;
	node->left = NULL;
	node->right = NULL;
	return node;
}
//建立二叉树定义
TreeNode* CreateTree()
{
	//开辟树并且对每个进行赋值
	TreeNode* node1 = BuyTreeNode(1);
	TreeNode* node2 = BuyTreeNode(2);
	TreeNode* node3 = BuyTreeNode(3);
	TreeNode* node4 = BuyTreeNode(4);
	TreeNode* node5 = BuyTreeNode(5);
	TreeNode* node6 = BuyTreeNode(6);

	//确定指向
	node1->left = node2;
	node1->right = node4;
	node2->left = node3;
	node4->left = node5;
	node4->right = node6;

	return node1;
}
int main()
{
	TreeNode* root = CreateTree();
	LevelOrder(root);
	BinaryTreeDestory1(root);
	root = NULL;
	return 0;
}

结果:

是不是满足了层序遍历,好了,现在如果我让你将每层的结果,一行打印一层结果,该如何写呢?
// 层序遍历定义(二:逐层遍历)
void LevelOrder2(TreeNode* root)
{
	Queue s1;
	QueueInit(&s1);
	int size = 1;
	//判断是否为空,不空的话,先压进一个
	if (root != NULL)
		QueuePush(&s1, root);
	while (!QueueEmpty(&s1))
	{
		while (size>0)
		{
			TreeNode* cur = QueueFront(&s1);
			QueuePop(&s1);
			printf("%d ", cur->date);
			//压入它的左右孩子
			if (cur->left)
				QueuePush(&s1, cur->left);
			if (cur->right)
				QueuePush(&s1, cur->right);
			size--;
		}
		printf("\n");
		size = QueueSize(&s1);
	}
	printf("\n");
}

结果:(还是上面的树)

三.判断二叉树是否是完全二叉树

判断一棵树是不是完全二叉树,我们还是可以利用栈来实现,这里很好理解,就直接展示代码了,里面都有注释。
//判断二叉树是否是完全二叉树
bool BinaryTreeComplete(TreeNode* root)
{
	Queue s1;
	QueueInit(&s1);
	//判断是否为空,不空的话,先压进一个
	if (root != NULL)
		QueuePush(&s1, root);
	//找到第一个空
	while (!QueueEmpty(&s1))
	{
		
		TreeNode* cur = QueueFront(&s1);
		QueuePop(&s1);
		if (cur == NULL)
			break;
		//压入它的左右孩子,注意:不用判断了		
		QueuePush(&s1, cur->left);
		QueuePush(&s1, cur->right);		
	}
	//第二步:如果在栈中还有非空,就说明不是完全二叉树
	//定理:如果不是完全二叉树,那么栈里面此时一定有数据了
	while (!QueueEmpty(&s1))
	{
		TreeNode* cur2 = QueueFront(&s1);
		QueuePop(&s1);
		if (cur2 != NULL)
			return false;
	}
	return true;
}

检查:

//建立二叉树定义
TreeNode* CreateTree()
{
	//开辟树并且对每个进行赋值
	TreeNode* node1 = BuyTreeNode(1);
	TreeNode* node2 = BuyTreeNode(2);
	TreeNode* node3 = BuyTreeNode(3);
	TreeNode* node4 = BuyTreeNode(4);
	TreeNode* node5 = BuyTreeNode(5);
	TreeNode* node6 = BuyTreeNode(6);
	TreeNode* node7 = BuyTreeNode(7);

	//确定指向
	node1->left = node2;
	node1->right = node4;
	node2->left = node3;
	node2->right = node7;
	node4->left = node5;
	//node3->left = node5;
	node4->right = node6;
	return node1;
}

对于这棵树结果为:
当然,你也可以自己去检查我的结果
对于树的中等部分就补充到这里了,后面我们还会讲一些高级的树,元旦快乐,bye!!!

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

设计循环队列——oj题622

. 个人主页:晓风飞 专栏:LeetCode刷题|数据结构|Linux 路漫漫其修远兮,吾将上下而求索 文章目录 题目要求:应该支持如下操作:示例:提示: 结构体定义队列的创建基本操作判断队列是否为空&#xf…

python 数据容器

数据容器概念 一个可以存储多个元素的python数据类型 python有的数据容器 list(列表) tuple(元组) str(字符串) set(集合) dct(字典) 列表 python的列表的数据类型可以是不同的 my_list ["1",123,True,[123,"3333",d,False]]for item in my_list:p…

第三部分使用脚手架:vue学习(61-65)

文章目录 61 创建vue脚手架![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/f71d4324be0542209e690ab9e886d199.png)62 分析脚手架结构63 render函数64 修改默认配置65 ref 属性 61 创建vue脚手架 写完vue文件,没有脚手架做翻译,浏览器不认识…

数据结构:图详解

图的存储方式 邻接矩阵 首先先创建图,这一个我们可以使用邻接矩阵或者邻接链 表来进行存储,我们要实现的无向图的创建,我们先创建 一个矩阵尺寸为n*n,n为图中的节点个数如图所示 可以看出图中有5个结点,那我们创建…

PostGIS学习教程十七:线性参考

PostGIS学习教程十七:线性参考 线性参考是一种表示要素的方法,这些要素可以通过引用一个基本的线性要素来描述。使用线性参照建模的常见示例包括: 公路资产,这些资产使用公路网络沿线的英里来表示。 道路养护作业,指…

AOP(面向切面编程)基于XML方式配置

概念解释:(理解基本概念方可快速入手) 连接点(joinpoint) 被拦截到的点,因为Spring只支持方法类型的连接点,所以在Spring中连接点指的就是被拦截到的方法。 切入点(pointcut&#x…

主题-----读微信公众号

1.SOA 面向服务的架构(Service-Oriented Architecture,SOA)还没有一个公认的定义。许多组织从不同的角度和不同的侧面对 SOA 进行了描述,较为典型的有以下三个: (1)W3C 的定义:SOA 是…

MySQL-DCL

DCL是数据控制语言,用来管理数据库用户,控制数据库的访问权限。 管理用户:管理哪些用户可以访问哪些数据库 1.查询用户 USE mysql; SELECT * FROM user; 注意: MySQL中用户信息和用户的权限信息都是记录在mysql数据库的user表中的…

D-Link DES-108 交换机

D-Link DES-108 交换机 1. 百兆交换机 8 口References ​ D-Link Corporation is a Taiwanese multinational networking equipment manufacturing corporation headquartered in Taipei, Taiwan. Taiwanese:adj. 台湾的 n. 台湾人 headquarter [hedkwɔ:tə]&#…

深入理解Python中的二分查找与bisect模块

💗💗💗欢迎来到我的博客,你将找到有关如何使用技术解决问题的文章,也会找到某个技术的学习路线。无论你是何种职业,我都希望我的博客对你有所帮助。最后不要忘记订阅我的博客以获取最新文章,也欢…

数据采集:获取有价值信息的关键步骤

在当今数据驱动的时代,数据已成为企业、组织和个人做出明智决策的重要依据。而数据采集作为数据分析和应用的第一步,其重要性不言而喻。本文将探讨数据采集的概念意义、方法工具、面临的挑战和应对策略以及注意事项。 一、数据采集的定义和重要性 &…

HTTP基础知识总结

目录 一、什么是HTTP? 二、与HTTP有关的协议 三、HTTP请求特征 四、HTTP组成格式 五、HTTP标头 1.通用标头 2.实体标头 3.请求标头 4.响应标头 六、HTTP状态码分类 我们在日常测试过程中,也可以通过浏览器F12简单定位是前端问题还是后端问题&a…

css学习之路:sass学习基础篇

SCSS 一、动态的样式语言 让CSS有变量的概念css有很多的缺点 语法不够强大,没有变量和合理的样式复用机制,导致难以维护,我们就可以使用动态样式语言,赋予CSS新的特性。常见的动态样式语言 scss/sass(scss兼容sass&am…

厚积薄发11年,鸿蒙究竟有多可怕

12月20日中国工程院等权威单位发布**《2023年全球十大工程成就》。本次发布的2023全球十大工程成就包括“鸿蒙操作系统”在内。入围的“全球十大工程成就”,主要指过去五年由世界各国工程科技工作者合作或单独完成且实践验证有效的,并且已经产生全球影响…

云尚办公项目学习

完整的笔记可以参考这个专栏,写的挺详细的:云尚办公课件笔记,come on boy form-create前端组件 formProps记录了表单有哪些表单项,分别是哪些类型(下拉,单选,输入框) formOptions记…

周鸿祎分享大模型十大趋势:2024将出现杀手级应用

1月5日,“2023年风马牛年终秀”上,三六零(601360.SH,下称“360”)集团创始人周鸿祎分享了对2024年大模型发展趋势的十大预测,呼吁企业树立AI信仰,All in AI。他认为,创新才能破局&am…

shell脚本实现九九乘法表

9*9乘法表 判断服务是否开启 1.查看80端口是否被监听 [rootlocalhost ~]# ss -an | grep 80 tcp LISTEN 0 128 *:80 *:* 2.查看80端口/httpd服务是否开启 [rootlocalhost ~]# n…

【Python学习】Python学习2

目录 【Python学习】Python学习2 1.前言2.基本语法2.1标识符2.2保留字2.3行和缩进2.4多行语句2.5 Python 引号2.6 Python注释2.7 Python空行2.8 等待用户输入2.9 print 输出2.10 多个语句构成代码组2.11 命令行参数 参考 文章所属专区 Python学习 1.前言 主要是Python基本语…

《Python自动化测试九章经》

Python是当前非常流行的一门编程语言,它除了在人工智能、数据处理、Web开发、网络爬虫等领域得到广泛使用之外,他也非常适合软件测试人员使用,但是,对于刚入行的测试小白来说,并不知道学习Python语言可以用来完成哪些测…

kali-Linux安装ARL灯塔教程以及timeout of 20000ms exceeded 的解决方法

FLAG:别和妈妈诉苦,她帮不上,也睡不着。 专研方向: docker,ARL资产灯塔系统 每日emo:天冷了,你还在坚持吗? 欢迎各位与我这个菜鸟交流学习 kali安装ARL灯塔教程 1.安装docker环境,…