数据结构:树/二叉树

一、树的概念

逻辑结构:层次结构,一对多

  1. 节点:树中的一个数据元素
  2. 根节点:树中的第一个节点,没有父节点
  3. 孩子节点:该节点的直接下级节点
  4. 父(亲)节点:该结点的直接上级节点
  5. 兄弟节点:有相同父亲节点的
  6. 祖先节点:该结点的间接上级节点
  7. 子孙节点:该结点的间接下级节点
  8. 堂兄弟节点:有相同的祖先节点,在树的同一层的节点
  9. 树的深度:取树中层次的最大值
  10. 节点的度:子节点的个数/分支个数
  11. 树的度:节点度的最大值
  12. 森林:多个树(大于等于2)
  13. 节点的深度:从根节点开始向下的层次

二、 二叉树

节点的度最大为2

严格区分左右子树

1.二叉树的概念

  1. 二叉树的度:最大为2
  2. 左子树:节点左侧的子树
  3. 右子树:节点右侧的子树
  4. 满二叉树:除了叶子节点外,每一个节点的度都为0,叶子节点只能在最后一层
  5. 叶子节点:度为0的节点
  6. 完全二叉树:可以由满二叉树从右侧删除子树得到

2.二叉树的五种形态

3.二叉树的性质

第n层上最多有:2^(n-1)

前n层上:2^n-1

二叉树的总节点数:总度数+1         (其中+1,加的是头节点)

 4.二叉树的遍历

先序:根左右

中序:左根右

后序:左右根

练习1(一只一棵树的中序遍历和其他两种中任意一种,即可画唯一的二叉树)

先序:ABDGHCEFI            中序:GDHBAECIF

练习2.

 中序遍历:HDMIBJNEAFKCG      后序遍历:HMIDNJEBKFGCA

 

三、功能

二叉树的结构体

#ifndef __TREE_H__
#define __TREE_H__
#include <stdio.h>
#include <stdlib.h>

typedef struct tree_node{
	char data;
	struct tree_node *lchild;//左孩子
	struct tree_node *rchild;//右孩子
}tree,*tree_p;


//创建节点的函数
tree_p creat_node(char data);
//创建二叉树(创建节点,再创建节点的左右子树)
//二叉树的左右子树,仍然是一个二叉树
tree_p creat_tree();
//先序遍历:根左右
void pri(tree_p T);
//中序遍历:左根右
void zx(tree_p T);
//后序遍历:左右根
void hx(tree_p T);

#endif

1.创建节点

//创建节点的函数
tree_p creat_node(char data){
	tree_p new=(tree_p)malloc(sizeof(tree));
	if(new==NULL){
		printf("申请空间失败\n");
		return NULL;
	}
	new->data=data;
	return new;
}

2.创建二叉树

//创建二叉树(创建节点,再创建节点的左右子树)
//二叉树的左右子树,仍然是一个二叉树
tree_p creat_tree(){
	char data='\0'; //定义一个char类型的变量初始化为'\0'
	//不然data就是一个随机值,防止随机为#
	scanf("%c",&data);
	getchar();//吸收垃圾字符
	if(data=='#'){  //#为停止字符
		return NULL;
	}
	tree_p T=creat_node(data);//创建根节点
	T->lchild=creat_tree();  //左子数仍然是一个子树
	T->rchild=creat_tree();
	return T;
}

3.先序遍历

//先序遍历:根左右
void pri(tree_p T){
	if(T==NULL){
		return;
	}
	printf("%c->",T->data);
	pri(T->lchild);//给根节点的左孩子调用先序遍历
	pri(T->rchild);//给根节点的右孩子调用先序遍历
}

4.中序遍历

//中序遍历:左根右
void zx(tree_p T){
		if(T==NULL){
		return;
	}
		zx(T->lchild);
		printf("%c->",T->data);
		zx(T->rchild);
}

5.后序遍历

//后序遍历:左右根
void hx(tree_p T){
	if(T==NULL){
		return;
	}
	hx(T->lchild);
	hx(T->rchild);
	printf("%c->",T->data);
}

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

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

相关文章

机器学习-02-机器学习算法分类以及在各行各业的应用

总结 本系列是机器学习课程的第02篇&#xff0c;主要介绍机器学习算法分类以及在各行各业的应用 本门课程的目标 完成一个特定行业的算法应用全过程&#xff1a; 定义问题&#xff08;Problem Definition&#xff09; -> 数据收集(Data Collection) -> 数据分割(Data…

初识Maven

介绍&#xff1a; web后端开发技术ApacheMaven是一个项目管理和构建工具&#xff0c;它基于项目对象模型&#xff08;POM&#xff09;的概念&#xff0c;通过一小段描述信息来管理项目的构建。安装&#xff1a;http://maven.apache.org/ Apache软件基金会&#xff0c;成立于19…

新能源汽车出海潮起,智能驾驶方案成差异化优势

2023年&#xff0c;中国汽车产销分别达3016.1万辆和3009.4万辆&#xff0c;巨大的规模之下是激烈的品牌竞争。由整车企业引领&#xff0c;汽车产业链的电动化智能化转型逐渐倒逼企业自行开拓成长空间。转型力度偏小、产品更新较慢的海外市场&#xff0c;成为蕴含金矿的待开掘目…

电子电器架构新趋势 —— 最佳着力点:域控制器

电子电器架构新趋势 —— 最佳着力点&#xff1a;域控制器 我是穿拖鞋的汉子&#xff0c;魔都中坚持长期主义的汽车电子工程师&#xff08;Wechat&#xff1a;gongkenan2013&#xff09;。 老规矩&#xff0c;分享一段喜欢的文字&#xff0c;避免自己成为高知识低文化的工程师…

mac电脑监控软件哪个好

在Mac电脑使用日益普及的今天&#xff0c;企业对于Mac终端的安全管理需求也日益增长。Mac电脑监控软件作为一种有效的管理工具&#xff0c;能够帮助企业提高数据安全性和员工工作效率。 在众多Mac电脑监控软件中&#xff0c;域智盾软件以其卓越的功能和性能脱颖而出&#xff0c…

【办公类-21-04】20240227单个word按“段落数”拆分多个Word(三级育婴师操作参考题目 有段落文字和表格 1拆13份)

作品展示 背景需求&#xff1a; 最近学育婴师&#xff0c;老师发了一套doc操作参考 但是老师是一节节授课的&#xff0c;每节都有视频&#xff0c;如果做在一个文档里&#xff0c;会很长很长&#xff0c;容易找不到。所以我需要里面的单独文字的docx。 以前的方法是 1、打开源…

论文阅读:SOLOv2: Dynamic, Faster and Stronger

目录 概要 Motivation 整体架构流程 技术细节 小结 论文地址&#xff1a;[2003.10152] SOLOv2: Dynamic and Fast Instance Segmentation (arxiv.org) 代码地址&#xff1a;GitHub - WXinlong/SOLO: SOLO and SOLOv2 for instance segmentation, ECCV 2020 & NeurIPS…

逆变器专题(10)-电流环控制参数设计

相应仿真原件请移步资源下载 对跟网型逆变器来说&#xff0c;电流环的PI参数设计尤其重要 如上图所示为电流环解耦控制模型 而电压、电流采样和计算都是在开关周期的中间时刻进行&#xff0c;SVPWM调制出的磁矢量需要在一个开关周期进行作用&#xff0c;因此&#xff0c;整个逆…

2024年腾讯云4核8G12M配置的轻量服务器同时支持多大访问量?

腾讯云4核8G服务器支持多少人在线访问&#xff1f;支持25人同时访问。实际上程序效率不同支持人数在线人数不同&#xff0c;公网带宽也是影响4核8G服务器并发数的一大因素&#xff0c;假设公网带宽太小&#xff0c;流量直接卡在入口&#xff0c;4核8G配置的CPU内存也会造成计算…

swagger-ui.html报错404,解决办法

swagger-ui.html报错404,解决办法&#xff01;现在后端开发项目中&#xff0c;为了节省时间&#xff0c;使用swagger插件&#xff0c;可以方便的快捷生成接口文档。但是如果你在请求前端页面路径比如&#xff1a;http://127.0.0.1:7777/swagger-ui.html。找不到。那是因为你的配…

Nginx网络服务六-----IP透传、调度算法和负载均衡

1.实现反向代理客户端 IP 透传 就是在日志里面加上一个变量 Module ngx_http_proxy_module [rootcentos8 ~]# cat /apps/nginx/conf/conf.d/pc.conf server { listen 80; server_name www.kgc.org; location / { index index.html index.php; root /data/nginx/html/p…

unity shaderGraph实例-物体线框显示

文章目录 本项目基于URP实现一&#xff0c;读取UV网格&#xff0c;由自定义shader实现效果优缺点效果展示模型准备整体结构各区域内容区域1区域2区域3区域4shader属性颜色属性材质属性后处理 实现二&#xff0c;直接使用纹理&#xff0c;使用默认shader实现优缺点贴图准备材质准…

振弦采集仪在高速公路岩土工程中的监测与评估

振弦采集仪在高速公路岩土工程中的监测与评估 河北稳控科技振弦采集仪是一种常用于结构振动监测的仪器&#xff0c;可以用于高速公路岩土工程中的监测与评估。它的原理是通过测量结构振动引起的振弦的变形来反映结构的振动情况。 在高速公路岩土工程中&#xff0c;振弦采集仪可…

【主题广范|见刊快】2024年电力电气与机械,能源工程国际会议(ICPEMEE 2024)

【主题广范|见刊快】2024年电力电气与机械&#xff0c;能源工程国际会议&#xff08;ICPEMEE 2024&#xff09; 重要信息 会议官网&#xff1a;http://www.icpemee.com会议地址&#xff1a;合肥截稿日期&#xff1a;2024.03.10召开日期&#xff1a;2024.03.20 &#xff08;先投…

图论基础(一)

一、图论 图论是数学的一个分支&#xff0c;它以图为研究对象。图论中的图是若干给定的点&#xff08;顶点&#xff09;以及连接两点的线&#xff08;边&#xff09;构成的图像&#xff0c;这种图形通常用来描述某些事物之间的某种特定关系&#xff0c;用点代表事物&#xff0c…

Springboot+vue的考务报名平台(有报告)。Javaee项目,springboot vue前后端分离项目。

演示视频&#xff1a; Springbootvue的考务报名平台&#xff08;有报告&#xff09;。Javaee项目&#xff0c;springboot vue前后端分离项目。 项目介绍&#xff1a; 本文设计了一个基于Springbootvue的前后端分离的考务报名平台&#xff0c;采用M&#xff08;model&#xff0…

【机器人最短路径规划问题(栅格地图)】基于遗传算法求解

基于遗传算法求解机器人最短路径规划问题&#xff08;栅格地图&#xff09;的仿真结果 仿真结果&#xff1a; 路径长度的变化曲线&#xff1a; 遗传算法优化后的机器人避障路径&#xff1a;

Leetcode 134. 加油站 java版 如何解决环路加油站算法

# 官网链接&#xff1a;. - 力扣&#xff08;LeetCode&#xff09; 1. 问题描述&#xff1a; 在一条环路上有 n 个加油站&#xff0c;其中第 i 个加油站有汽油 gas[i] 升。 你有一辆油箱容量无限的的汽车&#xff0c;从第 i 个加油站开往第 i1 个加油站需要消耗汽油 cost[i] 升…

Eclipse是如何创建web project项目的?

前面几篇描述先后描述了tomcat的目录结构和访问机制&#xff0c;以及Eclipse的项目类型和怎么调用jar包&#xff0c;还有java的main函数等&#xff0c;这些是一些基础问题&#xff0c;基础高清出来才更容易搞清楚后面要说的东西&#xff0c;也就是需求带动学习&#xff0c;后面…

Mendix 10.7 发布- Go Mac It!

在我们上个月发布了硕果累累的 Mendix 10.6 MTS 之后&#xff0c;您是否还没有抚平激动的情绪&#xff1f;好吧&#xff0c;不管您是否已经准备好&#xff0c;本月将带来另一个您想知道的大亮点——Mac版Studio Pro&#xff01;但这还不是全部。本月&#xff0c;我们还将推出Re…