初识二叉树

文章目录

  • 一.什么是树
  • 二.什么是二叉树
  • 三.二叉树的访问次序
  • 四.特殊的二叉树
  • 五.求结点个数
  • 六.平衡二叉树
  • 总结

一.什么是树

树是由一个集合以及在该集合上定义的一种关系构成的。 集合中的元素称为树的节点,所定义的关系称为父子关系。 父子关系在树的节点之间建立了一个层次结构。 在这种层次结构中有一个节点具有特殊的地位,这个节点称为该树的根节点,或称为树根。

结点

结点是数据结构中的基础,是构成复杂数据结构的基本组成单位。

结点的度

结点拥有的子树数目称为结点的度。

二.什么是二叉树

二叉树是n(n>=0)个结点的有限集合,该集合或者为空集(称为空二叉树),或者由一个根结点和两棵互不相交的、分别称为根结点的左子树和右子树组成。

特点

1.每一个节点最多有两棵子数,及二叉树不存在度大于二的节点

2.二叉树的子树有左右之分,其子树的次序不能够颠倒

3.任何一个二叉树都有三部分,根节点左子树右子树

结构

typedef int	BTDataType;
typedef struct Binary TreeNode
{struct Binary TreeNode* left;//左孩子struct Binary TreeNode* right;//右孩子BTDataType data;//数据
}BTNode;

三.二叉树的访问次序

3.1前序遍历 (根结点 > 左子树 > 右子树)

主要是利用了函数递归的方法去遍历,先根节点左子树右子树不断地去调用自己

void PreOrder(BTNode* root)
{if (root == NULL)return;printf("%d", root->data);//根PreOrder(root->left);//左子树PreOrder(root->right);//右子树}

3.2中序遍历和后序遍历

void MidOrder(BTNode* root)
{if (root == NULL)return;MidOrder(root->left);//左子树printf("%d", root->data);//根MidOrder(root->right);//右子树
}void afterOrder(BTNode* root)
{if (root == NULL)return;afterOrder(root->left);//左子树afterOrder(root->right);//右子树printf("%d", root->data);//根
}

3.3层序遍历

前中后序遍历其实也叫深度优化遍历,序遍历叫广度优化遍历

我们利用队列来实现层序遍历

核心思路:上一层带下一层的

先创造一个队列,如果跟节点不为空的话,把根节点放入这个队列中,循环的判断条件被列中没有元素就停下来,有元素就继续去队列投元素,放入树的头,然后再删去队列这个元素,然后把删去元素所对应的左子树和右子树放入,一层一层的遍历

void LeveOrder(BTNode* root)
{//创建队列Queue q;Queue Init(&q);//如果根节点不为空,在队列里放入if (root != NULL){QueuePush(&q, root);}while (!QueueEmpty(&q)){//删去元素所对应的左子树和右子树放入一层一层的遍历BTNode* front = QueueFront(&q);QueuePop(&q);printf("%c", front->data);if (front->left != NULL){QueuePush(&q, front->left);}if (front->right != NULL){QueuePush(&q, front->right);}}printf("\n");QueueDestory(&q);
}

四.特殊的二叉树

4.1满二叉树

假设一个满二叉树的高为h,则它的总结点个数为N,则高为2^0+2^1+....+2^(h-1)=N,h=log2(N+1)

4.2完全二叉树

特征:1.前n-1层是满的。2.最后一层不满,但最后一层从左往右都是连续的

特别公式:对于任何一颗二叉树,如果度为零的叶子节点个数为n0,度为二的分支节点个数为n2则n0=n2+1

例:存在一个2n个结点的完全二叉树,则它的叶子结点大小的个数为__

完全二叉树度为1的结点个数要么是1个,要么没有。设度为0的结点为x0,度为1的为x1,度为二的为x2,所以说套入两个公式,x0+x1+x2=2n,x0=x2+1.可以算出2x0+x1-1=2n,又因为完全二叉树所以x1为0或者1,带入可得n或者2n+1/2

五.求结点个数

其实二叉树还有一个平衡结构,叫做平衡二叉树,需要非常灵活的掌握函数递归和分治的思想,所以我们先来利用递归和分治思想来求一下结点

5.1求叶子结点的个数

利用递归和分治的思想

int TreeLeafsize(BTNode* root)
{if (root == NULL)return 0;//如果左子树和右子树都为空说明找到了一个叶子结点,返回1if (root->left == NULL && root->right == NULL)return 1;//利用函数递归的思路,先左子树在右return TreeLeafsize(root->left) + TreeLeafsize(root->right);
}

5.2求总结点个数

void Treesize(BTNode* root, int* psize)
{if (root == NULL){return;}//是结点就加加else{(*psize++);}//也是递归,分治先左子树在右子树Treesize(root->left,psize);Treesize(root->right,psize);
}

六.平衡二叉树

定义:平衡二叉树也叫AVL树,它或者是一颗空树,或者具有以下性质的二叉排序树:它的左子树和左子树的高度之差(平衡因子)的绝对值不超过1,且它的左子树和右子树都是一颗平衡二叉树。

6.1二叉树的深度

分治思路:如果为空高度直接为零,非空就分解子问题,先求左右指数的深度,我的深度等于左右,质数深度大的大小,加1。

int maxDepth(BTNode* root)
{if (root == NULL)return 0;int leftDepth = maxDepth(root->left);int rightDepth= maxDepth(root->right);//左边的深度如果大于右边的话,就加1反之右边加1return leftDepth > rightDepth ? leftDepth + 1 : rightDepth + 1;
}

6.2平衡树的判断

bool isBalaned(BTNode* root)
{//第一种情况,如果为空的话就是的if (root == NULL)return true;//利用深度函数来求出左右子树的深度int leftDepth = maxDepth(root->left);int rightDepth = maxDepth(root->right);//利用递归判断高度差的绝对值不超过1,左右都要是平衡二叉(递归)return abs(leftDepth - rightDepth) < 2 && isBalaned(root->left) && isBalaned(root->right);
}


总结

这只是初次学习二叉树,它的内容可不只有这些,还要深度的还需要不断的学习积累才可实现

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

RuoYi-Vue-Plus(基础知识点jackson、mybatisplus、redis)

一、JacksonConfig 全局序列化反序列化配置 1.1yml中配置 #时区 spring.jackson.time-zoneGMT8 #日期格式 spring.jackson.date-formatyyyy-MM-dd HH:mm:ss #默认转json的属性&#xff0c;这里设置为非空才转json spring.jackson.default-property-inclusionnon_null #设置属性…

JetPack之DataBinding基础使用

目录 一、简介二、使用2.1 使用环境2.2 xml文件绑定数据2.3 数据绑定的对象2.3.1 object2.3.2 ObseravbleField2.3.3 ObseravbleCollection 2.4 绑定数据 三、应用场景 一、简介 DataBinding是谷歌15年推出的library,DataBinding支持双向绑定&#xff0c;能大大减少绑定app逻辑…

python灾害应急救援平台flask-django-php-nodejs

灾害应急救援平台的目的是让使用者可以更方便的将人、设备和场景更立体的连接在一起。能让用户以更科幻的方式使用产品&#xff0c;体验高科技时代带给人们的方便&#xff0c;同时也能让用户体会到与以往常规产品不同的体验风格。 与安卓&#xff0c;iOS相比较起来&#xff0c;…

【Selenium(五)】

一、鼠标事件 from selenium import webdriver # 导入ActionChains类进行鼠标悬停操作 from selenium.webdriver.common.action_chains import ActionChains import time# 打开一个浏览器 # 法一、添加环境变量重启电脑 # 法二、填写浏览器驱动的绝对路径 driver webdriver.E…

功率半导体IGBT模块封装工艺

功率器件最近非常火热&#xff0c;作为新型功率半导体器件的主流器件&#xff0c;IGBT应用非常广泛&#xff0c;如家用电器、电动汽车、铁路、充电基础设施、充电桩&#xff0c;光伏、风能&#xff0c;工业制造、电机驱动&#xff0c;以及储能等领域。IGBT模块是新一代的功率半…

undo log

从这篇「执行一条 SQL 查询语句&#xff0c;期间发生了什么&#xff1f; (opens new window)」中&#xff0c;我们知道了一条查询语句经历的过程&#xff0c;这属于「读」一条记录的过程&#xff0c;如下图&#xff1a; 那么&#xff0c;执行一条 update 语句&#xff0c;期间发…

桌面显示器PD芯片:引领桌面显示技术的新篇章

随着科技的飞速发展&#xff0c;桌面显示器作为人们日常工作与生活中不可或缺的重要设备&#xff0c;其性能与品质也在不断提升。其中&#xff0c;PD芯片作为桌面显示器中的核心组件&#xff0c;发挥着至关重要的作用。本文将对桌面显示器PD芯片进行详细介绍&#xff0c;探讨其…

MD5源码(C语言描述)

本文介绍MD5源码&#xff08;C语言描述&#xff09;。 MD5(Message-Digest Algorithm 5)&#xff0c;即消息摘要算法5&#xff0c;是一种被广泛使用的消息散列算法。散列算法的基础原理是&#xff1a;将数据&#xff08;如一段文字&#xff09;经过运算转换为一段固定长度&…

#Linux(VMwareTOOL安装)

&#xff08;一&#xff09;发行版&#xff1a;Ubuntu16.04.7 &#xff08;二&#xff09;记录&#xff1a; &#xff08;1&#xff09; &#xff08;2&#xff09;打开虚拟机然后安装&#xff0c;出现灰色可能是已经安装过但是自己没有找到 &#xff08;3&#xff09;删除VM…

流畅切换Linux的应用程序

流畅切换Linux的应用程序 流畅切换Linux的应用程序一.Linux启动一个程序在后台执行1. 使用nohup和&&#xff1a;2. 使用ctrlZ&#xff1a;3.使用screen&#xff1a;3.1 创建会话3.2 要重新连接到此会话&#xff1a;3.3 中途退出会话&#xff0c;但程序继续运行:3.4 结束一个…

STM32的简单介绍

STM32是一种基于ARM Cortex-M内核的32位微控制器&#xff0c;由意法半导体公司开发和生产。STM32具有丰富的外设和功能&#xff0c;适用于各种应用场合&#xff0c;如工业控制、消费电子、物联网、人机交互等。STM32的优势包括低功耗、高性能、高可靠性、易于开发等。STM32的系…

上海晋名室外暂存柜助力新技术皮革制品生产行业安全

本周上海晋名又有一台室外危化品暂存柜项目通过验收&#xff0c;此次项目主要用于新技术皮革制品生产行业油桶、化学品等物资的室外暂存安全。 用户单位创立于2004年&#xff0c;是一家从事新技术皮革制品加工、生产的外资企业。 上海晋名作为一家专注工业安全防护领域&#…

基于消失点的相机自标定

基于消失点的相机自标定 附赠最强自动驾驶学习资料&#xff1a;直达链接 相机是通过透视投影变换来将3D场景转换为2D图像。在射影变换中&#xff0c;平行线相交于一点称之为消失点。本文详细介绍了两种利用消失点特性的标定方法。目的是为根据实际应用和初始条件选择合适的标…

SpingBoot集成Rabbitmq及Docker部署

文章目录 介绍RabbitMQ的特点Rabbitmq术语消息发布接收流程 Docker部署管理界面说明Overview: 这个页面显示了RabbitMQ服务器的一般信息&#xff0c;例如集群节点的名字、状态、运行时间等。Connections: 在这里&#xff0c;可以查看、管理和关闭当前所有的TCP连接。Channels: …

component-右侧抽屉组件

1.右侧抽屉组件 点击筛选&#xff0c;右侧抽屉滑出&#xff0c;点击取消或者点击空白处抽屉收起。 2.代码 <template><div class"all" click"hidden()"><!-- 抽屉 --><div class"drawer"><div class"drawerBo…

js处理数组分类

const obj [{"groupingType": "1","remark": "梨花带雨","totalRmbMoney": 7,"kyeGroupingType": "广州一组"},{"groupingType": "2","remark": "99","…

【蓝桥杯】第15届蓝桥杯青少组stema选拔赛C++中高级真题答案(20240310)

一、选择题 第 1 题 第 2 题 表达式1000/3的结果是( A )。 A.333 B.333.3 C.334 D.333.0 第 3 题 下列选项中&#xff0c;判断a等于1并且b等于1正确的表达式是( B )。 A.!((a!1)&&(b!1)) B.!((a!1)||(b!1)) C.!(a1)&&(b1) D.(a1)&&(b1) 【解析】 A…

测试用例设计指南

软件测试设计是测试过程中重要的测试活动&#xff0c;怎么样设计测试用例能提高我们测试的效率和质量&#xff0c;从以下几个方面做了简单的讲解。 1 测试用例设计原则 测试用例设计的基本原则包括&#xff1a;有效性、清晰性、可复用性、可维护性、完整性、兼容性、易操作性…

【数据可视化】Echarts官方文档及常用组件

个人主页 &#xff1a; zxctscl 如有转载请先通知 文章目录 1. 前言2. Echarts官方文档介绍3. ECharts基础架构及常用术语3.1 ECharts的基础架构3.2 ECharts的常用术语3.2.1 ECharts的基本名词3.2.2 ECharts的图表名词 4. 直角坐标系下的网格及坐标轴4.1 直角坐标系下的网格4.2…

360企业安全浏览器兼容模式显示异常某个内容不显示 偶发现象 本地无法复现情况js

360企业安全浏览器兼容模式显示异常 &#xff0c;现象测试环境频发 &#xff0c;本地连测试无法复现&#xff0c;线上反馈问题。 出现问题的电脑为windows且使用360企业安全浏览器打开兼容模式可复现 复现过程&#xff1a; 不直接点击超链接跳转页面 &#xff0c;登录后直接通…