java基础概念49-数据结构2

一、树

1-1、树的基本概念

1、树的节点

2、二叉树

3、树的高度

1-2、二叉查找树

普通二叉树没有规律,不方便查找,没什么作用

1、基本概念

2、添加节点

此时,该方式添加形成的二叉查找树,根节点就是第一个节点。

3、查找节点

4、二叉树的遍历

  • 前序遍历
  • 中序遍历
  • 后序遍历
  • 层序遍历 
①前序遍历

②中序遍历(最常用

获取到的数据是从小到大的!所以,这种遍历方式是最常见的!

③后序遍历

④层序遍历

5、二叉查找树的弊端 

此时,查询效率太低了!

一棵树想要提高查询效率,要树的左、右高度差不多!——平衡二叉树。

1-3、平衡二叉树

1、平衡二叉树的旋转机制

目的:在构建二叉树的时候,保持平衡。 

①、左旋

【示例1】:

左旋步骤1:(简单)

【示例2】:

左旋步骤2:(复杂)

②、右旋

【示例1】:

右旋步骤1:(简单)

【示例2】:

右旋步骤2:(复杂)

 

 

③、平衡二叉树需要旋转的四种情况
1、左左:一次右旋

 

 

2、左右:先局部左旋,再整体右旋

步骤一:局部左旋

步骤二:整体右旋

3、右右:一次左旋

4、右左:先局部右旋,再整体左旋

步骤一:局部右旋

步骤二:整体左旋

小结:

 1-4、小结-树的演变

1-5、红黑树

 1、红黑规则

2、构建红黑树

添加节点时,默认节点是红色的,因为效率高!(按照红黑规则调整的次数少!)

旋转的时候,先把叶子nil结点去掉,直接转,转完再把nil节点加上即可!

【示例】:

 【步骤一】:添加第一个节点

 【步骤二】:添加第二个节点

非根,父节点是黑色,不做调整。

 【步骤三】:添加第三个节点

 【步骤四】:添加第四个节点

非根,父红,叔叔红色:

 

 【步骤五】:添加第五个节点

非根,父节点是黑色,不做调整。

 

 【步骤六】:添加第六个节点

 

3、红黑树的性能

红黑树的增、删、改、查,性能都比较好!

在构建红黑树的过程中,调整次数多的是改变颜色(只是改变节点里面存储颜色的变量的值),旋转的操作(旋转操作比较耗时!),对比平衡二叉树,少太多了!

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

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

相关文章

GhatGPT缺陷不足和商业应用

1. 引言 ChatGPT的兴起: 2022年末推出,迅速在自然语言处理和人工智能领域引起广泛关注。数亿用户体验其强大智能,感叹机器智能的飞速发展。 存在的缺陷: 事实性错误:生成的文本中包含错误信息。无法实时更新&#xff1…

【Linux】Macvlan介绍及LInux下例子实现

Macvlan Macvlan 是一种网络虚拟化技术,允许在同一物理网络接口上创建多个虚拟网络接口,每个虚拟接口都有自己独立的 MAC 地址。这对于需要在同一物理主机上运行多个网络隔离的应用程序或容器时非常有用。 Macvlan 的特点和用途 独立的 MAC 地址 每个 …

Jackson @JsonInclude 注解

1. 概述 Jackson 是一个著名的Java库,以转换Java对象为JSON格式以及从JSON反序列化回Java对象而闻名。有时候,我们可能希望仅在某些字段满足特定条件时才将其包含在JSON输出中,而Jackson的JsonInclude注解正是为此目的量身定制的。 JsonInc…

12.12 枚举 共用体 数据结构 创建顺序表

1.思维导图 2. 创建顺序表 1>头文件 test.h #ifndef __TEST_H__ #define __TEST_H__#include<stdlib.h> #include<stdio.h> #include<string.h>#define MAX 30 //typedef int datatype;typedef struct sequence {int data[MAX];int len;}seqlist,*se…

next.js 存在缓存中毒漏洞(CVE-2024-46982)

免责声明: 本文旨在提供有关特定漏洞的深入信息,帮助用户充分了解潜在的安全风险。发布此信息的目的在于提升网络安全意识和推动技术进步,未经授权访问系统、网络或应用程序,可能会导致法律责任或严重后果。因此,作者不对读者基于本文内容所采取的任何行为承担责任。读者在…

如何对小型固定翼无人机进行最优的路径跟随控制?

控制架构 文章继续采用的是 ULTRA-Extra无人机&#xff0c;相关参数如下&#xff1a; 这里用于guidance law的无人机运动学模型为&#xff1a; { x ˙ p V a cos ⁡ γ cos ⁡ χ V w cos ⁡ γ w cos ⁡ χ w y ˙ p V a cos ⁡ γ sin ⁡ χ V w cos ⁡ γ w sin ⁡ χ…

【Flink-scala】DataStream编程模型之延迟数据处理

DataStream API编程模型 1.【Flink-Scala】DataStream编程模型之数据源、数据转换、数据输出 2.【Flink-scala】DataStream编程模型之 窗口的划分-时间概念-窗口计算程序 3.【Flink-scala】DataStream编程模型之水位线 4.【Flink-scala】DataStream编程模型之窗口计算-触发器-…

react useRef、useContext、useReducer使用中遇到的问题及解决办法

在 React 中&#xff0c;useRef、useContext 和 useReducer 是三个非常有用的 Hook&#xff0c;它们可以帮助我们更好地管理组件的状态和行为。然而&#xff0c;在使用这些 Hook 时&#xff0c;可能会遇到一些问题和困惑。本文将详细解释这三个 Hook 的工作原理&#xff0c;并提…

2024告别培训班 数通、安全、云计算、云服务、存储、软考等1000G资源分享

大类有&#xff1a;软考初级 软考中级 软考高级 华为认证 华三认证&#xff1a; 软考初级&#xff1a; 信息处理技术员 程序员 网络管理员 软考中级&#xff1a; 信息安全工程师 信息系统监理师 信息系统管理工程师 嵌入式系统设计时 数据库系统工程师 电子商务设…

《操作系统 - 清华大学》8 -1:进程的组成

文章目录 1. 进程的组成2. 进程与程序的联系3. 进程与程序的区别4. 进程与程序关系 1. 进程的组成 进程具体包含哪些东西&#xff1a; 首先要执行相应的代码&#xff0c;所以执行代码需要放到内存中代码执行需要处理数据&#xff0c;数据需要放到内存中需要知道现在要执行哪条…

【Java】String类API

创建字符串 字符串字面量"Hello"高效&#xff0c;常量池复用常见、简单的字符串创建 new 关键字new String("Hello")每次创建新对象&#xff0c;性能开销较高显式创建新对象 字符数组new String(char[])转换字符数组字符数组转字符串 StringBuilder/St…

数据结构初阶---二叉树---堆

一、树 1.树的概念 树是一种非线性的数据结构&#xff0c;由n(n≥0)个有限结点组成的一个有层次关系的集合。形状类似一棵倒挂的树&#xff0c;根朝上&#xff0c;分支向下。 根结点没有前驱结点&#xff0c;可以有n(n≥0)个后继结点。 其余结点被分为M个互不相交的集合&am…

CocosCreator对配置文件加密

一、加密 1.首先假设你已经将Excel表格数据导出为了json数据 2.然后可以通关nodejs对其进行xor加密 const fs require(fs);// 读取配置文件 const path "hero_info.json"; const data fs.readFileSync(path, utf-8); const jsonObject JSON.parse(data);// XO…

学习 Dockerfile 常用指令

学习 Dockerfile 常用指令 在构建 Docker 镜像时&#xff0c;Dockerfile 文件是一份至关重要的配置文件&#xff0c;它定义了构建镜像的所有步骤。通过在 Dockerfile 中使用不同的指令&#xff08;命令&#xff09;&#xff0c;我们可以控制镜像的构建过程、设置环境、指定执行…

D95【python 接口自动化学习】- pytest进阶之fixture用法

day95 pytest的fixture详解&#xff08;二&#xff09; 学习日期&#xff1a;20241210 学习目标&#xff1a;pytest基础用法 -- pytest的fixture详解&#xff08;二&#xff09; 学习笔记&#xff1a; fixture(autouseTrue) func的autouse是TRUE时&#xff0c;所有函数方法…

C语言 字符串输入输出函数、scanf(“%[^\n]“,)可输入空格 、fgets删除换行符

字符串输入函数&#xff1a; scanf&#xff08;"%s"&#xff0c;数组名&#xff09; gets&#xff08;数组名&#xff09; fgets&#xff08;&#xff09; --- 文件流输入函数 函数原型&#xff1a; int scanf( const char *format, ...…

深度学习camp-第J4周:ResNet与DenseNet结合探索

&#x1f368; 本文为&#x1f517;365天深度学习训练营 中的学习记录博客&#x1f356; 原作者&#xff1a;K同学啊 本周任务&#xff1a; 探索ResNet和DenseNet的结合可能性本周任务较难&#xff0c;我们在chatGPT的帮助下完成 一、网络的构建 设计一种结合 ResNet 和 Den…

「iOS」通过CoreLocation Framework深入了解MVC架构

「iOS」通过CoreLocation Framework重新了解多界面传值以及MVC架构 文章目录 「iOS」通过CoreLocation Framework重新了解多界面传值以及MVC架构前言CoreLocation了解根据需求建模设计属性方法设计协议传值Block传值KVONotification通知方式 总结参考文章 前言 在这个学期的前…

Debezium系列之:使用Debezium采集oceanbase数据库

Debezium系列之:使用Debezium采集oceanbase数据库 一、oceanbase数据库二、安装OceanBase三、安装oblogproxy四、基于Docker的简单采集案例五、生产实际应用案例Debezium 是一个开源的分布式平台,用于监控数据库变化和捕捉数据变动事件,并以事件流的形式导出到各种消费者。D…

线程sleep的时候会释放锁吗

来看一段代码&#xff1a; void task1(mutex &m) {cout << "thread 1 init..." << endl;{std::unique_lock<mutex> lock(m);cout << "thread 1 getLock" << endl;sleep(5);}cout << "thread 1 freeLock&quo…