当前位置: 首页 > news >正文

【Java】二叉树:数据海洋中灯塔式结构探秘(上)

4289bfb309f34a118d9d0e3a4019831d.gif

个人主页 🌹:喜欢做梦


二叉树中有一个树,我们可以猜到他和树有关,那我们先了解一下什么是树,在来了解一下二叉树

一🍝、树型结构

1🍨.什么是树型结构?

树是一种非线性的数据结构,它是由n(n>=0)个有限节点(结点)和边组成的层次结构的集合。有一个特定的节点为根节点,其余节点通过边连接形成的分支,每个节点可以有零个或多个子节点。把它叫做树是因为它看起来像一颗倒挂的树,也就是说它是根朝上,而叶朝下的。

3d152da2704b40e58e8f702eebd81937.png655be38b9cc745ecb7505dace130970a.png

什么是线性结构?什么是非线性结构?

线性结构:数据元素呈现一对一的线性关系,除第一个和最后一个元素外,每个元素都有且仅有一个直接前驱和一个直接后继;

非线性结构:数据元素之间的关系不是简单的一对一,一个元素可能有多个前驱或后继,或者两者都有。

  • 树的定义是递归的
  • 除根节点外每一个结点都能引出一颗子树;
  • 树型结构中,子树之间不能有交集,否则就不是树型结构; 
  • 除了跟节点之外,每个节点有且只有一个父节点
  • 一个N个节点的树有N-1条边,因为根节点的上方没有边;

2🍩.什么是非树型结构?

非树:节点间的连通性复杂,可能存在多个路径连接统一对节点,也肯存在孤立节点,即与其他节点无连接。

002a5cd166de4deba327ac94ecc30971.png

3🍪.树型结构的基本性质

5e9a0482a612454cb7e8641f5af1dabd.png

  • 结点的度一个结点含有子树的个数称为该结点的度;如上图,A的度为3,C的度为2;
  • 树的度:一颗树中,所有结点度的最大值称为结点的度;如上图,树的度为4;
  • 叶子结点或终端结点度为0节点称为叶结点;如上图,E、F、G、P等结点为叶节点;
  • 孩子结点或子结点:一个结点含有子树的根结点称为该结点的子结点即只有根节点的结点才是子节点;如上图,B是A的孩子结点;
  • 双亲结点或父亲结点:若一个结点含有子结点,则这个树称为该结点的父结点;如图上A是B的父节点;
  • 根结点:一个树没有双亲的结点;如上图,A;
  • 结点的层次:从根开始定义,根为第一层,根的子结点为第二层,一次类推;
  • 树的高度或深度:树中结点的最大层次;如上图,树的高度为4;
  • 以下只需了解的概念:
  • 非终端结点或分支结点除根结点外,度不为0的结点;如上图:B、C、D、H为分支节点;
  • 兄弟结点:具有相同父结点的结点互称为兄弟结点;如上图:B、C是兄弟结点;
  • 堂兄弟结点不具有同一个父结点,但双亲在同一层的结点互为堂兄弟;如上图,G和H;
  • 结点的祖先:从根到该结点所经分支的所有结点;如上图,A就是所有结点的祖先;
  • 子孙:以某结点为根的子树中的任一节点,都称为该结点的子孙。如上图,所有结点都是A的子孙;
  • 森林:有m(m>=0)互不相交的树组成的集合称为森林;

4🍨.树的表现形式(了解)

树的表现形式有很多种,如双亲表示法,孩子表示法、孩子双亲表示法、孩子兄弟表示法等等。这里简单了解一下其中最常见的方法就是孩子兄弟表示法:

class Node{public int value;//数据public Node firstChild;//第一个孩子public Node nextBrother;//下一个兄弟
}

8a8938db550a44828dc848a6cbed7e39.png

二🍝、二叉树

1🍑.什么是二叉树?

二叉树:二叉树是每个结点最多有两科子树的树的结构,其两个子树通常称为左子树和右子树

二叉树的递归定义:

  • 或者是一颗空树;
  • 或者是一颗由一根结点和两课互不相交的分别称为左子树和右子树所组成的非空数,左子树和右子树又同样是二叉树;

0948a72b839d46c0ab3b3a38cbab082f.png

特点:

  • 度的限制:结点的度最大为2;
  • 有序性:左右子树由顺序,即使某节点只有一颗子树,也要区分左右子树;

性质:

  • 若规定的根节点层数为1,这一棵非空二叉树的第i层上最多有eq?2%5E%7Bi-1%7D(i>.0)个节点;
  • 若规定只有根节点的二叉树的深度为1,则深度为k的二叉树的最大节点数是eq?2%5E%7Bk%7D-1(k>=0);
  • 对于任何一棵二叉树,如果其叶节点个数为n0,度为2的非叶节点个数为n2,则有n0=n2+1;
  • 对于一颗有n个节点的m个二叉树(m表示树的度),其最小深度计算公式:eq?%5Clog_%7Bm%7D(n(m-1)+1);

f12a02b2492a4d8890a3a466d63462d1.png

2🍑.二叉树的类型

1.满二叉树

满二叉树:每一层的结点树都达到最大,除最后一层外每个节点都有两个节点。

eeeabfbbc6c24894aab44b7d586a191d.png

特点:

  • 节点度数:除最后一层的叶子节点外,其他层的每一个的节点都有两个节点,即度都为2;
  • 叶子节点:所有的叶子节点都在同一层,且叶子节点的数量为eq?2%5E%7Bk-1%7D,k为数的高度;
  • 节点总数: 节点总数是eq?2%5E%7Bk%7D-1

9563a474a20f42bdb433782d220cb2fd.png

2.完全二叉树

完全二叉树:除最后一层外,其余层节点数都达到最大,最后一层节点从左到右依次按顺序排列,可通过数组的高效和访问,完全二叉树是满二叉树的一种

d85c274e594b47ed9cf6f4426afbd706.png

特点:

  • 节点度数:除了底层的叶子节点外,其余所有节点都有两个子节点,即度数均为2;
  • 叶子节点分布:所有叶子节点都在同一层,这使得树的结构呈现出完美的形态;
  • 具有n个节点的完全二叉树的深度k为eq?%5Clog_%7B2%7D(n+1)上取整进1;

总节点个数与叶子节点个数的关系: 

  • 如果总节点个数为偶数,那么叶子节点为总节点个数的一半,也就是n=2n0;
  • 如果总节点个数为奇数,那么叶子节点为总节点个数的一半再减一,也就是n=2n0-1;
  • 节点数量:对于具有n个节点的完全二叉树,如果按照从上至下从左至右的顺序对所有节点从0开始编号,这对于序号为i的节点有:
  • 若i>0,双亲序号:(i-1)/2;i=0,i为根节点的编号,无双亲节点;
  • 若2i+1<n,左孩子序号:2i+1,否则无左孩子;
  • 若2i+1<n,右孩子序号:2i+2,否则无右孩子; 

49929b888a0d4fb0b9029af25eea53d2.png

3🍪.二叉树的创建

fde4be67a312411f8ce3e8200c0cbc40.png

public class BinaryTree {public static class TreeNode{public char val;//数据public TreeNode left;//左孩子public TreeNode right;//右孩子public TreeNode(char val) {this.val = val;}}public TreeNode createTree(){//创建节点TreeNode A=new TreeNode('A');TreeNode B=new TreeNode('B');TreeNode C=new TreeNode('C');TreeNode D=new TreeNode('D');TreeNode E=new TreeNode('E');TreeNode F=new TreeNode('F');TreeNode G=new TreeNode('G');//连接节点A.left=B;A.right=C;B.left=D;B.right=E;C.left=F;C.right=G;return A;}
}

4.二叉树的遍历

二叉树的遍历是指按照一定的顺序访问二叉树中的每个节点,且每个节点仅被访问一次

二叉树的遍历方式主要有前序遍历、中序遍历、后序遍历;

前序遍历

前序遍历:遍历顺序是先访问根的的节点—>左子树—>右子树,也就是根、左、右;

a198f3fdace44be695330449675b29c1.png

 前序遍历代码:

// 前序遍历public void preOrder(TreeNode root){//判断是否有节点,没有返回if(root == null){return;}System.out.print(root.val+ " ");//遍历左子树preOrder(root.left);//遍历右子树preOrder(root.right);}

a0b4e7ef1c374aba8cf29baefc46b1ff.png

3f8e67209be0487fbd5c413401238c44.png bcc53479fa0f476497bf02c8bbeefb6f.png

  •  顺序:根节点--左子树--右子树;
  • 根结点的打印位置:第一个;

 中序遍历

中序遍历:遍历顺序是先访问左子树—>根的的节点—>右子树,也就是左、根、右;

54ccf1923033436dbdc0fa94ff200515.png

中序遍历代码: 

 // 中序遍历public void inOrder(TreeNode root){//判断是否有节点,没有返回if(root == null){return;}//遍历左子树preOrder(root.left);System.out.print(root.val+ " ");//遍历右子树preOrder(root.right);}

 

818481e07b5a4139aa2738f04d458d17.png 49562fc8df8443389426a81adc9cb705.png

b0d17ae796024aed99e4a3d4bab0663d.png d5360f9190eb498f8eebf9dca12fc3ce.png

 

0d0e081c78684a21af4330dbc76905f9.png

  • 顺序:左子树--根节点--右子树;
  • 根结点的打印位置:中间;

 后序遍历

 后序遍历:遍历顺序是先访问左子树—>右子树—>根的的节点,也就是左、根、右;

8d9a82cfe4554255ab36bc2c48051013.png

    // 后序遍历public void postOrder(TreeNode root){//判断是否有节点,没有返回if(root == null){return;}//遍历左子树preOrder(root.left);//遍历右子树preOrder(root.right);System.out.print(root.val+ " ");}
}

后序遍历的过程与前面的也是同理,就不画图过多解释了。 

  • 顺序:左子树--右子树--根节点;
  • 根结点的打印位置:最后一个;

三者之间的区别:

 前序遍历中序遍历后序遍历
访问顺序根、左、右左、根、右左、右、根
根节点访问位置第一个中间最后一个
应用场景二叉树结构、将表达式树转换为前缀表达式用于输出有序序列,还能辅助将表达式树转换为中缀表达式二叉树的高度、节点数,以及释放二叉树内存

 

层序遍历

层序遍历:从上至下,从左至右逐层访问就是层序遍历。

63a1afe44ad840ef8f7306852070d820.png

层序遍历的代码,我后期补上,或者下篇在写,这篇就到这里啦~ 

961e1dc9cbf04a488e6a5d9204a7355c.jpeg

 

我的博客即将同步至腾讯云开发者社区,邀请大家一同入驻:https://cloud.tencent.com/developer/support-plan?invite_code=3k88uddoizs48

 

相关文章:

【Java】二叉树:数据海洋中灯塔式结构探秘(上)

个人主页 &#x1f339;&#xff1a;喜欢做梦 二叉树中有一个树&#xff0c;我们可以猜到他和树有关&#xff0c;那我们先了解一下什么是树&#xff0c;在来了解一下二叉树 一&#x1f35d;、树型结构 1&#x1f368;.什么是树型结构&#xff1f; 树是一种非线性的数据结构&…...

微信小程序 WXS 的概念与基本用法教程

微信小程序 WXS 的概念与基本用法教程 引言 在微信小程序的开发中,WXS(WeiXin Script)是一种特殊的脚本语言,旨在解决小程序在逻辑处理和数据处理上的一些限制。WXS 允许开发者在小程序的 WXML 中嵌入 JavaScript 代码,以便实现更复杂的逻辑处理。本文将深入探讨 WXS 的…...

Vue.js 中 v-bind 和 v-model 的用法与异同

简介 在 Vue.js 中&#xff0c;v-bind 和 v-model 是两个非常常用且强大的指令&#xff0c;它们分别用于动态地绑定属性和实现双向数据绑定。理解这两个指令的用法和区别对于构建 Vue.js 应用至关重要。本文将详细介绍 v-bind 和 v-model 的用法&#xff0c;并探讨它们的异同。…...

K8s的水平自动扩容和缩容HPA

HPA全称是Horizontal Pod Autoscaler&#xff0c;翻译成中文是POD水平自动伸缩&#xff0c;HPA可以基于CPU利用率对replication controller、deployment和replicaset中的pod数量进行自动扩缩容&#xff08;除了CPU利用率也可以基于其他应程序提供的度量指标custom metrics进行自…...

【AI日记】24.11.26 聚焦 kaggle 比赛

【AI论文解读】【AI知识点】【AI小项目】【AI战略思考】【AI日记】 核心工作 1 内容&#xff1a;研究 kaggle 比赛时间&#xff1a;3 小时 核心工作 2 内容&#xff1a;学习 kaggle 比赛 Titanic - Machine Learning from Disaster时间&#xff1a;4 小时备注&#xff1a;这…...

大型语言模型LLM - Finetuning vs Prompting

资料来自台湾大学李宏毅教授机器学课程ML 2023 Spring&#xff0c;如有侵权请通知下架 台大机器学课程ML 2023 Springhttps://speech.ee.ntu.edu.tw/~hylee/ml/2023-spring.php2023/3/10 课程 機器如何生成文句 内容概要 主要探讨了大型语言模型的两种不同期待及其导致的两类…...

【IEEE独立出版 | 厦门大学主办】第四届人工智能、机器人和通信国际会议(ICAIRC 2024,12月27-29日)

第四届人工智能、机器人和通信国际会议&#xff08;ICAIRC 2024&#xff09; 2024 4th International Conference on Artificial Intelligence, Robotics, and Communication 重要信息 会议官网&#xff1a;www.icairc.net 三轮截稿时间&#xff1a;2024年11月30日23:59 录…...

【GPT】力量训练是什么,必要吗,有可以替代的方式吗

什么是力量训练&#xff1f; 力量训练是一种通过抵抗力&#xff08;如重量、阻力带、自身体重等&#xff09;来刺激肌肉收缩&#xff0c;从而提高肌肉力量、耐力和体积的运动形式。它包括以下常见形式&#xff1a; 自由重量训练&#xff1a;使用哑铃、杠铃、壶铃等。固定器械…...

【03】Selenium+Python 八种定位元素方法

操作元素&#xff0c;需要先查找定位到对应的元素。 查找单个元素&#xff1a;driver.find_element() 返回是一个web element 对象 查找多个元素&#xff1a;driver.find_elements() 返回是一个list对象 By 是 Selenium 中一个非常重要的类&#xff0c;用于定位网页元素。 使…...

笔记:jQuery追加js时会自动加“_时间戳“参数,导致百度统计失败

问题描述&#xff1a; $(document.createElement("script")).attr(id, baidutj).attr(src, https://hm.baidu.com/hm.js?xxx).appendTo(body); 会自动给src加_时间戳的参数&#xff1f; 问题解疑&#xff1a; 【未完待续…】 问题解决&#xff1a; 老老实实按它…...

【PyTorch】(基础二)---- 张量

张量 在 PyTorch 中&#xff0c;张量&#xff08;Tensor&#xff09;是核心数据结构&#xff0c;类似于 NumPy 中的数组&#xff0c;但具有更强的计算能力和对 GPU 的支持。 创建 从列表或数组创建 import torch# 从列表创建 tensor_from_list torch.tensor([1, 2, 3, 4])…...

充满智慧的埃塞俄比亚狼

非洲的青山 随着地球温度上升&#xff0c;贝尔山顶峰的冰川消失殆尽&#xff0c;许多野生动物移居到海拔3000米以上的高原上生活&#xff0c;其中就包括埃塞俄比亚狼。埃塞俄比亚狼是埃塞俄比亚特有的动物&#xff0c;总数不到500只&#xff0c;为“濒危”物种。 埃塞俄比亚狼…...

基于STM32设计的智能桌面暖风机(华为云IOT)

一、前言 1.1 项目开发背景 随着智能家居技术的迅猛发展&#xff0c;传统家用电器正逐步向智能化方向转型。暖风机作为冬季广泛使用的取暖设备&#xff0c;其智能化升级不仅能够提高用户的使用体验&#xff0c;还能通过物联网技术实现远程控制和数据监控&#xff0c;赋予其更…...

零基础学安全--云技术基础

目录 学习连接 前言 云技术历史 云服务 公有云服务商 云分类 基础设施即服务&#xff08;IaaS&#xff09; 平台即服务&#xff08;PaaS&#xff09; 软件即服务&#xff08;SaaS&#xff09; 云架构 虚拟化 容器 云架构设计 组件选择 基础设施即代码 集成部署…...

Spring Boot中配置Flink的资源管理

在 Spring Boot 中配置 Flink 的资源管理&#xff0c;需要遵循以下步骤&#xff1a; 添加 Flink 依赖项 在你的 pom.xml 文件中&#xff0c;添加 Flink 和 Flink-connector-kafka 的依赖项。这里以 Flink 1.14 版本为例&#xff1a; <!-- Flink dependencies --><de…...

51单片机从入门到精通:理论与实践指南入门篇(二)

续51单片机从入门到精通&#xff1a;理论与实践指南&#xff08;一&#xff09;https://blog.csdn.net/speaking_me/article/details/144067372 第一篇总体给大家在&#xff08;全局&#xff09;总体上讲解了一下51单片机&#xff0c;那么接下来几天结束详细讲解&#xff0c;从…...

Notepad++ 替换所有数字给数字加单引号

前言 今天遇到这样一个场景&#xff1a; 要去更新某张表里 code1,2,3,4,5,6 的数据&#xff0c;把它的 name 设置为 ‘张三’ 但是 code在数据库里面的字段类型是 vachar(64)&#xff0c;它自身携带索引 原本可以这样写 SQL: update tableA set namezhangsan where code in …...

【CANOE】【Capl】【RS232】控制串口设备

系列文章目录 内置函数&#xff0c;来控制传统的串口设备&#xff0c;比如继电器等 文章目录 系列文章目录前言一、控制串口二、自定义相关的参数RS232Configure**函数语法****函数功能****参数说明****返回值****示例代码** 三、回调函数的使用RS232OnSend**函数语法****函数…...

查找相关题目

1.顺序查找法适合于存储结构为&#xff08;B &#xff09;的线性表。 A.散列存储 B.顺序存储或链式存储 C.压缩存储 D.索引存储 顺序查找法的特点 2.适用于折半查找的表的存储方式及元素排列要求为(D ) 。 A.链接方式存储&#xff0c;元素无序 B.链接方式存储&#xff0…...

《独立开发:Spring 框架的综合应用》

一、Spring 框架概述 Spring 是一个分层的 Java SE/EE full-stack 轻量级开源框架&#xff0c;以 IoC 和 AOP 为内核&#xff0c;具有方便解耦、方便集成优秀框架、降低 Java EE API 使用难度等优点。 Spring 框架因其强大的功能以及卓越的性能而受到众多开发人员的喜爱。它是…...

Python爬虫实战:研究MechanicalSoup库相关技术

一、MechanicalSoup 库概述 1.1 库简介 MechanicalSoup 是一个 Python 库,专为自动化交互网站而设计。它结合了 requests 的 HTTP 请求能力和 BeautifulSoup 的 HTML 解析能力,提供了直观的 API,让我们可以像人类用户一样浏览网页、填写表单和提交请求。 1.2 主要功能特点…...

linux之kylin系统nginx的安装

一、nginx的作用 1.可做高性能的web服务器 直接处理静态资源&#xff08;HTML/CSS/图片等&#xff09;&#xff0c;响应速度远超传统服务器类似apache支持高并发连接 2.反向代理服务器 隐藏后端服务器IP地址&#xff0c;提高安全性 3.负载均衡服务器 支持多种策略分发流量…...

【JavaEE】-- HTTP

1. HTTP是什么&#xff1f; HTTP&#xff08;全称为"超文本传输协议"&#xff09;是一种应用非常广泛的应用层协议&#xff0c;HTTP是基于TCP协议的一种应用层协议。 应用层协议&#xff1a;是计算机网络协议栈中最高层的协议&#xff0c;它定义了运行在不同主机上…...

iPhone密码忘记了办?iPhoneUnlocker,iPhone解锁工具Aiseesoft iPhone Unlocker 高级注册版​分享

平时用 iPhone 的时候&#xff0c;难免会碰到解锁的麻烦事。比如密码忘了、人脸识别 / 指纹识别突然不灵&#xff0c;或者买了二手 iPhone 却被原来的 iCloud 账号锁住&#xff0c;这时候就需要靠谱的解锁工具来帮忙了。Aiseesoft iPhone Unlocker 就是专门解决这些问题的软件&…...

关于iview组件中使用 table , 绑定序号分页后序号从1开始的解决方案

问题描述&#xff1a;iview使用table 中type: "index",分页之后 &#xff0c;索引还是从1开始&#xff0c;试过绑定后台返回数据的id, 这种方法可行&#xff0c;就是后台返回数据的每个页面id都不完全是按照从1开始的升序&#xff0c;因此百度了下&#xff0c;找到了…...

【第二十一章 SDIO接口(SDIO)】

第二十一章 SDIO接口 目录 第二十一章 SDIO接口(SDIO) 1 SDIO 主要功能 2 SDIO 总线拓扑 3 SDIO 功能描述 3.1 SDIO 适配器 3.2 SDIOAHB 接口 4 卡功能描述 4.1 卡识别模式 4.2 卡复位 4.3 操作电压范围确认 4.4 卡识别过程 4.5 写数据块 4.6 读数据块 4.7 数据流…...

五年级数学知识边界总结思考-下册

目录 一、背景二、过程1.观察物体小学五年级下册“观察物体”知识点详解&#xff1a;由来、作用与意义**一、知识点核心内容****二、知识点的由来&#xff1a;从生活实践到数学抽象****三、知识的作用&#xff1a;解决实际问题的工具****四、学习的意义&#xff1a;培养核心素养…...

el-switch文字内置

el-switch文字内置 效果 vue <div style"color:#ffffff;font-size:14px;float:left;margin-bottom:5px;margin-right:5px;">自动加载</div> <el-switch v-model"value" active-color"#3E99FB" inactive-color"#DCDFE6"…...

Python实现prophet 理论及参数优化

文章目录 Prophet理论及模型参数介绍Python代码完整实现prophet 添加外部数据进行模型优化 之前初步学习prophet的时候&#xff0c;写过一篇简单实现&#xff0c;后期随着对该模型的深入研究&#xff0c;本次记录涉及到prophet 的公式以及参数调优&#xff0c;从公式可以更直观…...

Cinnamon修改面板小工具图标

Cinnamon开始菜单-CSDN博客 设置模块都是做好的&#xff0c;比GNOME简单得多&#xff01; 在 applet.js 里增加 const Settings imports.ui.settings;this.settings new Settings.AppletSettings(this, HTYMenusonichy, instance_id); this.settings.bind(menu-icon, menu…...