数据结构:树/二叉树

一、树的概念

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

  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);
}

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

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

相关文章

用友U8 Cloud KeyWordReportQuery SQL注入漏洞复现

0x01 产品简介 用友U8 Cloud是用友推出的新一代云ERP,主要聚焦成长型、创新型企业,提供企业级云ERP整体解决方案 0x02 漏洞概述 用友U8 Cloud KeyWordReportQuery接口处存在SQL注入漏洞,未授权的攻击者可通过此漏洞获取数据库权限,从而盗取用户数据,造成用户信息泄露。…

D*算法超详解 (D星算法 / Dynamic A*算法/ Dstar算法)(死循环解决--跟其他资料不一样奥)

所需先验知识&#xff08;没有先验知识可能会有大碍&#xff0c;了解的话会对D*的理解有帮助&#xff09;&#xff1a;A*算法/ Dijkstra算法 何为D*算法 Dijkstra算法是无启发的寻找图中两节点的最短连接路径的算法&#xff0c;A*算法则是在Dijkstra算法的基础上加入了启发函数…

MRP区域--库位用法

路径&#xff1a;SPRO->生产->物料需求计划->主数据->MRP 区域->定义工厂/存储地点的 MRP 范围 业务理解&#xff1a;通常情况下&#xff0c;是以整个工厂跑MRP。实际业务中存在部分特殊库位的库存不参与MRP运行&#xff0c;如报废仓库存。这时我们可以启用库…

程序员如何看待祖传代码

所谓的祖传的代码主要在存留很长时间的代码而且很可能里面很多隐患&#xff0c;通常状态下如果祖传的代码不是很复杂作为程序员来讲都会不自觉地给重构下&#xff0c;如果是非常复杂的模块即使程序员想重构但是考虑后续的影响可能是心有余而力不足&#xff0c;除非公司或者部门…

vue2.0及起步(前端面试知识积累)

1、需要了解的vue概要知识 1、vue是什么&#xff1f; 一套用于构建用户界面的渐进式JavaScript框架。 为什么vue被称为是渐进式JS框架&#xff1f; 答&#xff1a;Vue允许开发者在不同的项目中以渐进式的方式使用它&#xff0c;这种渐进式表现在以下的方面&#xff1a; 逐步采…

Jupyterlab 和 JupyternoteBook 修改默认路径

Jupyterlab 和 JupyternoteBook 修改默认路径 在使用 JupyterLab 或 Jupyter Notebook 进行数据分析、机器学习项目时&#xff0c;经常会遇到需要修改默认工作目录的需求。默认情况下&#xff0c;JupyterLab 和 Jupyter Notebook 会在启动时打开你的用户目录&#xff08;例如&…

XSS原理和攻防

Cross Site Scripting:跨站脚本攻击 用户提交的数据中可以构造恶意代码&#xff0c;并且执行&#xff0c;从而实现窃取用户信息等攻击 攻击&#xff1a; 防御&#xff1a; 1.对输入进行过滤&#xff0c;对输出进行编码 2.cookie设置http-only

python:xml.etree.ElementTree 读 Freeplane.mm文件,生成测试案例.csv文件

Freeplane 是一款基于 Java 的开源软件&#xff0c;继承 Freemind 的思维导图工具软件&#xff0c;它扩展了知识管理功能&#xff0c;在 Freemind 上增加了一些额外的功能&#xff0c;比如数学公式、节点属性面板等。 强大的节点功能&#xff0c;不仅仅节点的种类很多&#xf…

一文详细拆解Agent工作原理

一、写在前面 Agent&#xff0c;中文译为“代理”或“智能体”&#xff0c;是一种能够在特定环境中自主行动、感知环境、做出决策并与其他Agent或人类进行交互的计算机程序或实体。它们具备自主性、反应性、社交性和适应性等特点&#xff0c;能够根据环境的变化调整自己的行为…

搜维尔科技:第九届元宇宙数字人大赛,参赛小组报名确认公告

各位参赛选手大家好&#xff0c;近期已收到新增报名信息如下表&#xff0c;请各位参赛选手确认&#xff0c;如果信息有误或信息不完整请电话联系赛务组工作人员进行更正 随着元宇宙时代的来临&#xff0c;数字人设计成为了创新前沿领域之一。为了提高大学生元宇宙虚拟人角色策划…

热闹元宵进行中,如何利用VR全景展示民宿品牌形象?

错峰出游闹元宵&#xff0c;元宵节恰逢周末&#xff0c;而且还是春节假期返工之后的首个休息日&#xff0c;不少人都想通过短途度假来缓解“节后综合征”。两位数的特价机票、打折的各种酒店让你实现“旅行自由”&#xff0c;那么如何知道特价酒店服务好不好呢&#xff1f;先别…

动静态库的理解

其实我们平常写一些C或C的代码的时候&#xff0c;在链接过程都会用到动静态库&#xff0c;因为一些基础的代码我们是不用写的&#xff08;比如输入输出函数&#xff09;&#xff0c;我们只需要包个头文件&#xff0c;这些库和我们的编译好的代码一起链接后才会形成可执行程序 那…

进程概念与进程状态

目录 一、进程理解和进程控制块 进程理解 Linux中的进程 查看进程 1.ps ajx 查看所有的进程信息 2. /proc/目录查看 系统调用接口 getpid() 获取进程的pid ​编辑 getppid() 获取进程的父进程的pid fork创建进程 fork用法: fork原理理解: 二、进程状态 进程状态…

TensorFlow训练大模型做AI绘图,需要多少的GPU算力支撑

TensorFlow训练大模型做AI绘图&#xff0c;需要多少的GPU算力支撑&#xff01;这个问题就涉及到了资金投资的额度了。众所周知&#xff0c;现在京东里面一个英伟达的显卡&#xff0c;按照RTX3090(24G显存-涡轮风扇&#xff09;版本报价是7000-7500之间。如果你买一张这样的单卡…

十一、Qt自定义Widget组件、静态库与动态库

一、自定义Widget组件 1、自定义Widget组件 使用步骤采用提升法&#xff08;promotion&#xff09;重新定义paintEvent事件 2、实现程序 &#xff08;1&#xff09;创建项目&#xff0c;基于QWidget &#xff08;2&#xff09;添加类&#xff0c;为Widget组件提升类 #inclu…

day44 ● 完全背包● 518. 零钱兑换 II ● 377. 组合总和 Ⅳ

完全背包和01背包问题唯一不同的地方就是&#xff0c;每种物品有无限件。 首先再回顾一下01背包的核心代码 for(int i 0; i < weight.size(); i) { // 遍历物品for(int j bagWeight; j > weight[i]; j--) { // 遍历背包容量dp[j] max(dp[j], dp[j - weight[i]] val…

(二十)devops持续集成开发——使用jenkins的docker插件完成docker项目的流水线发布

前言 本节内容主要介绍jenkins如何集成docker插件&#xff0c;完成docker项目的流水线发布&#xff0c;在前面的章节中我们也介绍过docker项目的发布&#xff0c;可直接通过shell命令调用本地的docker服务完成docker项目的发布&#xff0c;本节内容我们使用docker插件来完成do…

Open CASCADE学习|视图

目录 Mainwin.h Mainwin.cpp Mainwin.h ​#pragma once#include <QtWidgets/QMainWindow>#include "Displaywin.h"#include "OCC.h"class Mainwin : public QMainWindow{ Q_OBJECTpublic: Mainwin(QWidget* parent nullptr); ~Mainwin();​pri…

Stable Diffusion 绘画入门教程(webui)-ControlNet(Shuffle)

Shuffle(随机洗牌)&#xff0c;这个预处理器会把参考图的颜色打乱搅拌到一起&#xff0c;然后重新组合的方式重新生成一张图&#xff0c;可以想象出来这是一个整体风格控制的处理器。 那么问题来了&#xff0c;官方为啥会设计个这样的处理器呢&#xff0c;主要是给懒人用的&am…

idea生成WebServices接口

文章目录 idea生成WebServices接口1.创建接口2.生成wsdl文件3.在soapUI中&#xff0c;生成6个文件4.将生成的文件拷贝到工程中5.在service-config中注册服务 idea生成WebServices接口 1.创建接口 新建一个webServices工程&#xff0c;按照接口规范生成接口、请求类、响应类。…