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

《数据结构之美--二叉树》

一:引言:

上次我们学习了栈和队列这两个数据结构,今天我们来学习一个新的数据结构–二叉树中的堆。
堆其实就是一种特殊的二叉树,具有二叉树的性质的同时,还具有其他的性质。
那么在学习堆之前还是先来了解一下树。

二:树

1.树的概念与结构

树是⼀种非线性的数据结构,它是由 n(n>=0) 个有限结点组成⼀个具有层次关系的集合。把它叫做
树是因为它看起来像⼀棵倒挂的树,也就是说它是根朝上,而叶朝下的。

在数据结构中树的结构如下图所示:
在这里插入图片描述
树有⼀个特殊的结点,称为根结点,根结点没有前驱结点。
上面这棵树的根节点就是A
除根结点外,其余结点被分成 M(M>0)个互不相交的集合 T1、T2、……、Tm,其中每⼀个集合Ti(1 <= i <= m)又是⼀棵结构与树类似的子树。每棵子树的根结点有且只有⼀个前驱,可以有 0个或多个后继。因此,树是递归定义的。

注:树形结构中,子树之间不能有交集。
例如下面的这些就不是树,而是图
在这里插入图片描述

  1. 子树是不相交的(如果存在相交就是图了)
  2. 除了根结点外,每个结点有且仅有⼀个父结点
  3. ⼀棵N个结点的树有N-1条边

2. 树的相关术语

在这里插入图片描述

  1. 父结点/双亲结点:若⼀个结点含有子结点,则这个结点称为其子结点的父结点;
    如上图:A是B的父结点。
  2. 子结点/孩子结点:⼀个结点含有的子树的根结点称为该结点的子结点;
    如上图:B是A的孩子结点。
  3. 结点的度:⼀个结点有几个孩子,他的度就是多少;
    比如A的度为6,F的度为2,K的度为0。
  4. 树的度:⼀棵树中,最大的结点的度称为树的度;
    如上图:树的度为 6。
  5. 叶子结点/终端结点:度为 0的结点称为叶结点;
    如上图: B、C、H、I…等结点为叶结点。
  6. 分支结点/非终端结点:度不为 0的结点;
    如上图: D、E、F、G…等结点为分支结点。
  7. 兄弟结点:具有相同父结点的结点互称为兄弟结点(亲兄弟);
    如上图: B、C是兄弟结点。
  8. 结点的层次:从根开始定义起,根为第 1层,根的子结点为第 2层,以此类推;
  9. 树的高度或深度:树中结点的最大层次;
    如上图:树的高度为 4。
  10. 结点的祖先:从根到该结点所经分支上的所有结点;
    如上图: A是所有结点的祖先。
  11. 路径:⼀条从树中任意节点出发,沿父节点-子节点连接,达到任意节点的序列;比如A到Q的路径为:A-E-J-Q;H到Q的路径H-D-A-E-J-Q
  12. 子孙:以某结点为根的子树中任⼀结点都称为该结点的子孙。
    如上图:所有结点都是A的子孙。
  13. 森林:由 m(m>0)棵互不相交的树的集合称为森林。

3. 树的表示

孩子兄弟表示法:

的结构相对线性表就比较复杂了,要存储表示起来就比较麻烦了,既然保存值域,也要保存结点和结点之间的关系,实际中有很多种表示方式如:双亲表示法孩子表示法孩子双亲表示法以及孩子兄弟表示法等。我们这里就简单的了解其中最常用的孩子兄弟表示法

struct TreeNode
{
struct Node* child; // 左边开始的第⼀个孩⼦结点
struct Node* brother; // 指向其右边的下⼀个兄弟结点
int data; // 结点中的数据域
};
下面来看一棵树的存储:

这是一颗二叉树
在这里插入图片描述
这是二叉树的节点的物理存储结构:
在这里插入图片描述

4. 树形结构的实际应用场景

文件系统是计算机存储和管理文件的⼀种方式,它利用树形结构来组织和管理文件和文件夹。在文件系统中,树结构被广泛应用,它通过父结点子结点之间的关系来表示不同层级的文件和文件夹之间的关联。
在这里插入图片描述
在这里插入图片描述

三:二叉树

1. 概念与结构

在树形结构中,我们最常用的就是二叉树,⼀棵⼆叉树是结点的一个有限集合,该集合由一个根结点加上两棵别称为左子树和右子树的二叉树组成或者为空。

在这里插入图片描述
从上图可以看出二叉树具备以下特点:

  1. 二叉树不存在度大于 2 的结点。
  2. 二叉树的子树有左右之分,次序不能颠倒,因此二叉树有序树

注:二叉树都是由以下几种情况复合而成的:
在这里插入图片描述

现实中的二叉树
在这里插入图片描述

四:特殊的二叉树

1. 满二叉树

⼀个二叉树,如果每⼀个层的结点数都达到最大值,则这个⼆叉树就是满⼆叉树。也就是说,如果⼀个⼆叉树的层数为 K,且结点总数是2 ^ K − 1,则它就是满⼆叉树
在这里插入图片描述

2. 完全二叉树

完全二叉树是效率很高的数据结构,完全二叉树是由满二叉树而引出来的。对于深度为K的,有 n 个结点的⼆叉树,当且仅当其每⼀个结点都与深度为K的满二叉树中编号从 1至 n 的结点一 一对应时称之为完全二叉树。要注意的是满二叉树是一种特殊的完全二叉树
在这里插入图片描述

3. 二叉树性质

根据满二叉树的特点可知:

  1. 若规定根节点的层数为1,则一颗非空二叉树的第k层上最多有2^(k - 1)个节点。
  2. 若规定根节点的层数为1,则深度为h的二叉树的最大节点数为 2^k - 1
  3. 若规定根节点的层数为1,具有n个节点的满二叉树的深度h = log2(n + 1)

五: 二叉树存储结构

二叉树一般可以使用两种结构存储,一种顺序结构,一种链式结构

1. 顺序结构

顺序结构存储就是使用数组来存储,一般使用数组只适合表示完全二叉树,因为不是完全二叉树会有空间的浪费,完全二叉树更适合使用顺序结构存储。

在这里插入图片描述
在这里插入图片描述
现实中我们通常把(⼀种二叉树)使用顺序结构数组来存储,需要注意的是这里的操作系统虚拟进程地址空间中的堆是两回事,一个是数据结构,一个是操作系统管理内存的一块区域分段

2. 链式结构

二叉树链式存储结构是指,用链表来表示⼀棵二叉树,即用链来指示元素的逻辑关系。通常的方法是链表中每个结点由三个域组成,数据域左右指针域,左右指针分别用来给出该结点左孩子右孩子所在的链结点的存储地址。链式结构又分为二叉链三叉链,当前我们学习中一般都是二叉链。等后面学到高阶数据结构红黑树等会用到三叉链
在这里插入图片描述

在这里插入图片描述

六:实现顺序结构的二叉树:堆

约定:这里我们按照大根堆的逻辑来实现,只要大根堆的逻辑实现了,小根堆只需在一些地方简单修改即可。

⼀般使用顺序结构数组来存储数据,是一种特殊二叉树,具有二叉树的特性的同时,还具备其他的特性。

1. 堆的结构和性质

在这里插入图片描述

小根堆图示:

在这里插入图片描述

大根堆图示:

在这里插入图片描述

堆的性质:
  1. 中某个结点的值总是不大于不小于父结点的值;
  2. 总是一棵完全二叉树

在这里插入图片描述

2. 定义堆结构

在这里插入图片描述

3. 初始化

声明:

在这里插入图片描述

逻辑实现:

在这里插入图片描述

4. 入堆

声明:

在这里插入图片描述

逻辑分析:

入堆很简单,和顺序表的插入数据相同,但难点是在插入数据之后还要维护该为一个大根堆,这里我们的处理方法是:空间足够的情况下直接往最后面插入,接着执行向上调整算法,直到满足大根堆

向上调整算法
  1. 先将元素插入到堆的末尾,即最后⼀个孩子之后。
  2. 插入之后如果的性质遭到破坏,将新插入结点顺着其双亲往上调整到合适位置即可
    下面给出一次向上调整算法执行过程的图示:

在这里向上调整算法维护的是小根堆
在这里插入图片描述

向上调整算法逻辑实现:

由于牵扯到数组元素的交换,所以这里我们封装一个交换函数:
在这里插入图片描述

在这里插入图片描述

向上调整算法时间复杂度分析:

在这里插入图片描述
分析:
第一层,2^0 个节点,需要向上移动0层
第二层,2^1个节点, 需要向上移动1层
第三层,2^3个节点, 需要向上移动2层

第h层,2^(h - 1) 个节点, 需要向上移动h - 1层
则需要移动结点总的移动步数为:每层结点个数*向上调整次数(第⼀层调整次数为0)

在这里插入图片描述
向上调整算法建堆时间复杂度为:O(n∗ log2 n)

逻辑实现:

在这里插入图片描述

测试:

在这里插入图片描述
可以看到大根堆的堆顶元素为最大的78,测试正常。

5. 判空

既然要出堆,那么你的中要有元素才可以,因此这里实现一个判空函数

声明:

在这里插入图片描述

逻辑实现:

在这里插入图片描述

6. 出堆

声明:

在这里插入图片描述

逻辑分析:

出堆是针对堆顶元素进行的操作,但考虑到之前顺序表都是在尾部删除,这里的也是在尾部进行,因此出堆的流程是:先将堆顶元素与堆的最后一个元素交换位置,然后删去最后一个元素,再执行向下调整算法,直到重新成为大根堆

向下调整算法

向下调整算法有⼀个前提:左右子树必须是一个堆,才能调整

向下调整算法

  1. 堆顶元素与堆中最后⼀个元素进行交换。
  2. 删除最后一个元素
  3. 堆顶元素向下调整到满足特性为止。

先将堆顶元素与最后一个元素交换,然后删去最后一个元素。
在这里插入图片描述

之后从堆顶执行向下调整算法
在这里插入图片描述

向下调整算法逻辑实现

:这里因为我们循环结束的条件为孩子节点走到最后,因此这里传参要多一个堆中有效元素的个数。
在这里插入图片描述

在这里插入图片描述

向下调整算法时间复杂度分析:

在这里插入图片描述

分析:
第1层,2 ^ 0 个结点,需要向下移动h-1层
第2层,2 ^ 1个结点,需要向下移动h-2层
第3层,2 ^ 2个结点,需要向下移动h-3层
第4层,2 ^ 3个结点,需要向下移动h-4层
…第h-1层,2 ^ h - 2 个结点,需要向下移动1层
则需要移动结点总的移动步数为:每层结点个数 * 向下调整次数
在这里插入图片描述
在这里插入图片描述
向下调整算法建堆时间复杂度为:O(n)

逻辑实现:

在这里插入图片描述

测试:

在这里插入图片描述
可以看到我们两次删除都是删去了堆顶元素,测试正常。

7. 取出堆顶元素

声明:

在这里插入图片描述

逻辑实现:

在这里插入图片描述

测试:

在这里插入图片描述
可以看到我们每次取堆顶元素时,取出的都是大根堆中最大的元素。

8. 打印函数

由于我们实现的顺序存储的,因此打印其实就是打印顺序表的逻辑。

声明:

在这里插入图片描述

逻辑实现:

在这里插入图片描述

测试:

在这里插入图片描述

8. 销毁

声明:

在这里插入图片描述

逻辑实现:

在这里插入图片描述

测试:

在这里插入图片描述

七:实现链式结构的二叉树

链表来表示一棵二叉树,即用来指示元素的逻辑关系。通常的方法是链表中每个结点由三个域组成,数据域左右指针域,左右指针分别用来给出该结点左孩子和右孩子所在的链结点的存储地址

1. 手搓二叉树:

链式二叉树结构:

在这里插入图片描述

构建二叉树:

在这里插入图片描述

在这里插入图片描述

遍历二叉树:

按照规则,二叉树的遍历有:前序/中序/后序的递归结构遍历:
1)前序遍历(PreorderTraversal 亦称先序遍历):访问根结点的操作发生在遍历其左右子树之前
访问顺序为:根结点、左子树、右子树
2)中序遍历(Inorder Traversal):访问根结点的操作发生在遍历其左右子树之中(间)
访问顺序为:左子树、根结点、右子树
3)后序遍历(Postorder Traversal):访问根结点的操作发生在遍历其左右子树之后
访问顺序为:左子树、右子树、根结点

前序遍历:
声明:

在这里插入图片描述

逻辑实现:

在这里插入图片描述

中序遍历:
声明:

在这里插入图片描述

逻辑实现:

在这里插入图片描述

后序遍历:
声明:

在这里插入图片描述

逻辑实现:

在这里插入图片描述

打印测试:

在这里插入图片描述

递归逻辑图:

在这里插入图片描述

2. 求二叉树节点个数

声明:

在这里插入图片描述

逻辑分析:

在这里插入图片描述

逻辑实现:

在这里插入图片描述

测试:

在这里插入图片描述
经过调用求二叉树节点的函数在打印可以发现没问题。

3. 求二叉树的叶子节点个数

声明:

在这里插入图片描述

逻辑分析:

在这里插入图片描述

逻辑实现:

在这里插入图片描述

测试:

在这里插入图片描述

4. 求二叉树第K层节点个数

声明:

在这里插入图片描述

逻辑分析:

在这里插入图片描述

逻辑实现:

在这里插入图片描述

测试:

在这里插入图片描述

5. 求二叉树深度

声明:

在这里插入图片描述

逻辑分析:

在这里插入图片描述

逻辑实现:

在这里插入图片描述

测试:

在这里插入图片描述

6. 查找二叉树中的值

声明:

在这里插入图片描述

逻辑分析:

在这里插入图片描述

逻辑实现:

在这里插入图片描述

测试:

先来测试一个二叉树中不存在的节点:
在这里插入图片描述
再测试一个二叉树中存在的节点::

8. 层序遍历(广度优先遍历)

除了先序遍历中序遍历后序遍历外,还可以对二叉树进行层序遍历。设二叉树根结点所在层数为1层序遍历就是从所在二叉树根结点出发,首先访问第层的根结点,然后从左到右访问第层上的结点,接着是第层的结点,以此类推,自上而下自左至右逐层访问树的结点的过程就是层序遍历

声明:

在这里插入图片描述

逻辑分析:

在这里插入图片描述

逻辑实现:

注:这里用到了之前实现的队列,需要加入队列的文件,而且这里还需要注意一个点
tree.c文件中需要包含队列的头文件Queue.h
由于队列需要存储二叉树的节点,因此这里的数据类型为结构体指针,这里在重定义时还要加上关键字struct
在这里插入图片描述

在这里插入图片描述

测试:

在这里插入图片描述

9. 判断二叉树是否为完全二叉树

声明:

在这里插入图片描述

逻辑分析:

在这里插入图片描述

在这里插入图片描述

逻辑实现:

在这里插入图片描述
在这里插入图片描述

测试:

这时候二叉树为非完全二叉树
在这里插入图片描述
我们改变一下链接构造一颗完全二叉树
在这里插入图片描述
可以看到测试没问题。

10. 销毁二叉树

:这里为了改变传入的根节点指针,因此传入了根节点指针的地址(二级指针)
这就是省去了在外面手动将root置为空的操作。

声明:

在这里插入图片描述

逻辑分析:

+-

逻辑实现:

在这里插入图片描述

测试:

在这里插入图片描述

总结:

这篇博客主要介绍了,包括关于的一些术语树的表示树在计算机中的应用树的分类树的两种存储结构->顺序存储结构链式存储结构
下次会分享一些二叉树oj题。

相关文章:

《数据结构之美--二叉树》

一&#xff1a;引言&#xff1a; 上次我们学习了栈和队列这两个数据结构&#xff0c;今天我们来学习一个新的数据结构–二叉树中的堆。 堆其实就是一种特殊的二叉树&#xff0c;具有二叉树的性质的同时&#xff0c;还具有其他的性质。 那么在学习堆之前还是先来了解一下树。 …...

Prompt Engineering 提示工程:释放大语言模型潜力的关键技术与实践指南

提示工程:释放大语言模型潜力的关键技术与实践指南 提示工程(Prompt Engineering)作为与大型语言模型(LLM)交互的核心技术,已成为AI应用开发的关键技能。本文将系统介绍提示工程的定义与发展历程,深入剖析其核心知识点,提供实用的设计框架与技巧,并通过丰富的实战案例展示…...

std::print 和 std::println

一、基本概念 std::print 和 std::println 是 C23 新增的格式化输出函数&#xff0c;旨在替代传统的 std::cout 链式调用。它们基于 std::format 实现&#xff0c;支持类型安全的格式化字符串&#xff0c;语法更简洁&#xff0c;性能更优15。 功能特点&#xff1a; 直接输出到…...

高压直流输电MATLAB/simulink仿真模型+说明文档

1.模型简介 本仿真模型基于MATLAB/Simulink&#xff08;版本MATLAB 2018Ra&#xff09;软件。建议采用matlab2018 Ra及以上版本打开。&#xff08;若需要其他版本可联系代为转换&#xff09; 使用一个传输功率为1000MW&#xff08;500 kV&#xff0c;2 kA&#xff09;直流互连…...

第十四章-PHP与HTTP协议

第十四章-PHP与HTTP协议 一&#xff0c;HTTP 协议详解 HTTP&#xff08;HyperText Transfer Protocol&#xff0c;超文本传输协议&#xff09;是互联网上应用最广泛的协议之一&#xff0c;用于客户端&#xff08;如浏览器&#xff09;与服务器之间的通信。它是 Web 技术的基石…...

【阿里云大模型高级工程师ACP学习笔记】2.6.用插件扩展答疑机器人的能力边界

一、学习目标 备考阿里云大模型高级工程师ACP认证,深入学习《2.6.用插件扩展答疑机器人的能力边界》这部分内容,主要期望达成以下目标: 理解智能体应用核心概念:理解智能体(Agent)应用的核心概念,包括其如何拓展大模型能力,突破传统答疑机器人局限。掌握构建Agent系统…...

用远程代理模式轻松实现远程服务调用,打开编程新大门

通过远程代理来实现一个简易的远程过程调用实例。带你打开新的大门。 Socket 远程代理服务案例 基于 Socket 的远程服务&#xff0c;我们需要完成以下步骤&#xff1a; 服务端实现&#xff1a;创建一个远程服务&#xff0c;通过 Socket 接受客户端请求并提供计算服务。 客户端…...

(001)Excel 快捷键

文章目录 时间 时间 当前日期&#xff1a;ctrl ; (分号)。当前时间&#xff1a;ctrl Shift ; (分号)。...

TMI投稿指南(二):投稿文章注意事项

文章结构&#xff1a; https://journals.ieeeauthorcenter.ieee.org/create-your-ieee-journal-article/create-the-text-of-your-article/structure-your-article/ 补充材料&#xff1a;准备补充材料 - IEEE 作者中心期刊 --- Prepare Supplementary Materials - IEEE Author…...

从困局到破局的AI+数据分析

从困局到破局的AI数据分析 困局&#xff1a;数据分析的四道高墙破局&#xff1a;AI赋能全流程数据分析远见&#xff1a;AI数据分析的革命性意义 数据是新时代的石油&#xff0c;人工智能是炼油厂。当两者强强联合&#xff0c;一场数据分析的革命正悄然发生。 多少次你面对Excel…...

12. RANSAC点云多平面拟合分割

本文看了博客RANSAC点云多平面拟合分割-CSDN博客的文章&#xff0c;该博客将多平面拟合分割讲的很详细了&#xff0c;这里只是作为笔记用。 1.RANSAC算法原理 三维平面拟合&#xff08;最小二乘法&#xff09; 具体实现见下面代码&#xff1a; def SVD(points):# 二维&#…...

Prompt

提示工程指南 | Prompt Engineering GuideGoogle 官方提示工程 (Prompt Engineering)白皮书 | 宝玉的分享https://www.geeksforgeeks.org/what-is-prompt-engineering-the-ai-revolution/Prompt Engineering for Reasoning ModelsPrompt Engineering with Reasoning Models 1.p…...

[特殊字符] SpringCloud项目中使用OpenFeign进行微服务远程调用详解(含连接池与日志配置)

&#x1f4da; 目录 为什么要用OpenFeign&#xff1f; 在cart-service中整合OpenFeign 2.1 引入依赖 2.2 启用OpenFeign 2.3 编写Feign客户端 2.4 调用Feign接口 开启连接池&#xff0c;优化Feign性能 3.1 引入OkHttp 3.2 配置启用OkHttp连接池 3.3 验证连接池生效 Feign最佳…...

迈瑞医疗:国际业务增长21.28% 发展中国家成重要增长引擎

4月28日&#xff0c;迈瑞医疗&#xff08;300760.SZ&#xff09;发布2024年年度报告。报告期内&#xff0c;公司实现营业收入367.26亿元&#xff0c;同比增长5.14%&#xff1b;实现归母净利润116.68亿元&#xff0c;同比增长0.74%&#xff1b;经营活动产生的现金流量净额124.25…...

「地平线」创始人余凯:自动驾驶尚未成熟,人形机器人更无从谈起

温馨提示&#xff1a;运营团队2025年最新原创报告&#xff08;共210页&#xff09; —— 正文&#xff1a; 近日&#xff0c;国内智驾芯片上市公司[地平线]创始人兼CEO余凯&#xff08;先生&#xff09;接受腾讯新闻访谈时&#xff0c;提到如今大火的人形机器人&#xff0c;核…...

R 语言科研绘图第 43 期 --- 桑基图-冲击

在发表科研论文的过程中&#xff0c;科研绘图是必不可少的&#xff0c;一张好看的图形会是文章很大的加分项。 为了便于使用&#xff0c;本系列文章介绍的所有绘图都已收录到了 sciRplot 项目中&#xff0c;获取方式: R 语言科研绘图模板 --- sciRplothttps://mp.weixin.qq.c…...

SpringBoot应用原生或docker镜像容器集成Skywalking

相关组件及版本 序号 组件 版本 备注 1 skywalking-oap-server 8.9.1 2 elasticsearch 7.17.6 3 skywalking-ui 8.9.1 4 apache-skywalking-java-agent 8.15.0 一、JAR包方式部署服务 下载apache-skywalking-java-agent jar文件 使用如下名称执行 java \ -j…...

模板--进阶

1. 非类型模板参数 模板解决了两类问题 1控制数据类型 2控制某种设计逻辑 类域可以直接访问什么&#xff1f; 1static修饰的静态成员变量 2typedef定义的内嵌类型 3 内部类 下面我们就要引出一个模板的知识点----------再用类模板的时候从类模板里面去取东西的时候 要…...

PostgreSQL无法查看表中数据问题排查

在 PostgreSQL 中&#xff0c;恢复数据库后&#xff0c;使用 DBeaver 等工具可以看到数据库和表名&#xff0c;但无法查询到表中数据&#xff0c;可能是以下原因之一。以下是可能的原因和解决方法&#xff1a; 1. 恢复未完全成功 原因&#xff1a;数据库恢复过程中可能未完全成…...

实验研究 | 千眼狼高速摄像机驱动精密制造创新

研究背景 小模数齿轮作为精密制造领域的核心组件&#xff0c;以“结构紧凑、重量轻、精度高”等优势&#xff0c;广泛应用于航空航天、工业机器人、精密仪器、医疗设备、新能源和微电机等领域。传统抛光技术效率低、成本高、表面质量不足&#xff0c;电解等离子体抛光技术&am…...

AWS虚拟专用网络全解析:从基础到高级实践

导语 AWS虚拟专用网络是连接企业本地数据中心与AWS云环境的关键桥梁。本文将深入探讨AWS VPN的核心概念、配置方法、最佳实践以及常见问题解决方案,助您构建安全、可靠的混合云网络架构。 一、AWS VPN概述 1. 定义 AWS VPN是一种网络服务,允许用户通过加密隧道将本地网络…...

工业园区工厂企业数字IP广播应急呼叫对讲系统:数字IP广播极大提升工厂企业管理效率与应急响应效能

工业园区工厂企业数字IP广播应急呼叫对讲系统:数字IP广播极大提升工厂企业管理效率与应急响应效能 北京海特伟业科技有限公司任洪卓发布于2025年4月28日 在数字化转型浪潮下&#xff0c;IP应急广播呼叫对讲广播系统凭借其网络化、智能化、融合化、多元化等优势&#xff0c;已…...

我的HTTP和HTTPS

注释&#xff1a;本文章架构跟随小林coding&#xff0c;在此基础上加深个人理解 小林coding&#xff1a;https://xiaolincoding.com/network/2_http/http_interview.html HTTP基本概念 HTTP是什么&#xff1f; http的中文名是超文本传输协议&#xff0c;超文本就是html&…...

python_股票月数据趋势判断

目录 前置 代码 视频&月数据 前置 1 A股月数据趋势大致判断&#xff0c;做一个粗略的筛选 2 逻辑&#xff1a; 1&#xff09;取最近一次历史最高点 2&#xff09;以1&#xff09;中最高点为分界点&#xff0c;只看右侧数据&#xff0c;取最近一次最低点 3&#xf…...

计算机考研精炼 计网

第 19 章 计算机网络体系结构 19.1 基本概念 19.1.1 计算机网络概述 1.计算机网络的定义、组成与功能 计算机网络是一个将分散的、具有独立功能的计算机系统&#xff0c;通过通信设备与线路连接起来&#xff0c;由功能完善的软件实现资源共享和信息传递的系统。 …...

大数据应用开发和项目实战-Matplotlib

Matplotlib的介绍 Matplotlib 是 Python 的绘图库&#xff0c;它能让使用者很轻松地将数据图形化&#xff0c;并且提供多样化的输出格式。 Matplotlib 可以用来绘制各种静态&#xff0c;动态&#xff0c;交互式的图表。比如说散点图、柱状图等等。 Matplotlib的安装与…...

SQLMesh CLI 实战教程: 构建和维护数据转换管道的快速指南

在数据工程领域&#xff0c;构建和维护数据转换管道是一项复杂而关键的任务。SQLMesh 是一个强大的工具&#xff0c;可以帮助你简化这一过程。本文将带你快速了解如何使用 SQLMesh CLI 来构建和维护数据转换管道。本文的目标是在 30 分钟或更短的时间内&#xff0c;让你熟悉 SQ…...

行政区划代码

本文数据来源&#xff1a;中华人民共和国民政部 在平常数据研究和开发中&#xff0c;经常会用到行政区划代码。而行政区划代码的使用&#xff0c;因年份不同可能也不尽完全相同。故整理了1980年到2024年所有的行政区划代码。 这样不仅仅适用于研究区划代码的变更研究&#xf…...

Spring生命周期

在Spring框架中&#xff0c;Bean的生命周期指的是从Bean的创建到销毁的整个过程。这个过程包括了多个阶段&#xff0c;每个阶段都有特定的操作。下面是一个典型的Spring Bean生命周期的概述&#xff1a; 一. 实例化&#xff08;Instantiation&#xff09; 当Spring容器启动时&…...

前端连接websocket服务报错 Unexpected response code: 301

前端连接websocket服务报错 Unexpected response code: 301 引直连测试301重定向修改nginx配置 引 websocket后端服务正常&#xff0c;监听正常&#xff0c;可以通过简单的前端代码进行连接&#xff0c;但是通过nginx反向代理后报错Error during WebSocket handshake: Unexpec…...

C语言(5)—操作符详解

文章目录 一、操作符分类概览二、二进制与进制转换2.1 进制基本概念 三、原码、反码与补码3.1 基本概念 四、位操作符详解 一、操作符分类概览 C语言中的操作符可以分为以下几大类&#xff1a; 算术操作符&#xff1a;, -, *, /, % 移位操作符&#xff1a;<<, >>…...

ubuntu新增磁盘挂载

1. 确认新磁盘 使用 lsblk 命令查看系统中所有的块设备&#xff0c;找出新增的磁盘。 rootzzwl:~# lsblk NAME MAJ:MIN RM SIZE RO TYPE MOUNTPOINTS sda 8:0 0 60G 0 disk ├─sda1 8:1 0 …...

【计网】计算机网络的类别与性能

一、计算机网络的分类 计算机网络可以根据不同的标准进行分类。下面是两种常见的分类方法&#xff1a; 1.按照网络的作用范围进行分类 广域网 (WAN): 广域网覆盖的范围非常广泛&#xff0c;通常跨越城市、国家或甚至是全球。WAN主要用于连接地理位置相隔较远的计算机和网络设…...

Field访问对象int字段,对象访问int字段,通过openjdk17 C++源码看对象字段访问原理

在Java反射机制中&#xff0c;访问对象的int类型字段值&#xff08;如field.getInt(object)&#xff09;的底层实现涉及JVM对内存偏移量的计算与直接内存访问。本文通过分析OpenJDK 17源码&#xff0c;揭示这一过程的核心实现逻辑。 一、字段偏移量计算 1. Java层初始化偏移量…...

香橙派打包qt文件报错“xcb 插件无法加载”与“QObject::moveToThread”线程错误的解决方案

PyQt 报错总结&#xff1a;打包文件过程&#xff0c;“xcb 插件无法加载”与“QObject::moveToThread”线程错误的解决方案全解析 在使用 PyQt5 搭建图形界面时&#xff0c;打包文件的过程中出现的问题&#xff0c;真难绷&#xff0c;搞了半天。 Qt 平台插件 xcb 无法加载QOb…...

Flutter 学习之旅 之 flutter 作为 module ,在 Android 的界面中嵌入Flutter界面功能的简单整理

Flutter 学习之旅 之 flutter 作为 module &#xff0c;在 Android 的界面中嵌入Flutter界面功能的简单整理 目录 Flutter 学习之旅 之 flutter 作为 module &#xff0c;在 Android 的界面中嵌入Flutter界面功能的简单整理 一、简单介绍 二、在同一个布局中同时显示 Androi…...

在android 系统上qnn sdk转换,运行模型示例

前面讲了如何配置qnn sdk的环境&#xff0c;这一篇总结下qnn 实际转换一个onnx 模型&#xff0c;并运行的实现步骤。 设备&#xff1a; 1. ubuntu22.04 的Linux 服务器。 2. 一台android手机。 一、下载模型 from optimum.onnxruntime import ORTModelForSequenceClassifi…...

docker安装Canal1.1.5,MySQL5.7踩坑

docker安装Canal 前情提示安装MySQLdocker安装MySQL1. 拉取镜像2. 创建容器映射宿主机目录3. docker run 配置mysql重启mysql新建canal用户 安装Canal创建docker网络安装Canal1.拉取canal镜像2.创建目录3.运行容器 踩坑问题1 前情提示 关于版本问题&#xff0c;官方也没有详细…...

SpringBoot 接口国际化i18n 多语言返回 中英文切换 全球化 语言切换

介绍 Spring Boot通过MessageSource接口来实现国际化&#xff0c;它可以加载不同的消息资源文件&#xff0c;通常是.properties格式。通过定义不同的语言文件&#xff08;例如&#xff1a;messages_en.properties、messages_zh.properties等&#xff09;&#xff0c;可以根据用…...

C++ 嵌套类 (详解 一站式讲解)

目录 嵌套类 嵌套类的定义 嵌套类结构的访问权限 pimpl模式&#xff08;了解&#xff09; 嵌套类 嵌套类的定义 首先介绍两个概念&#xff1a; 类作用域&#xff08;Class Scope&#xff09; 类作用域是指在类定义内部的范围。在这个作用域内定义的成员&#xff08;包括…...

EasyCVR视频汇聚平台助力大型生产监控项目摄像机选型与应用

一、方案背景 在300路大型生产监控项目中&#xff0c;由于生产环境复杂多样&#xff0c;涵盖室外厂区、大型车间、室内办公区域等不同场景&#xff0c;单一类型的摄像机难以满足全方位、精细化的监控需求。EasyCVR作为一款功能强大的视频融合管理平台&#xff0c;具备灵活的视…...

解决leensa无法使用的办法:平替教程

Leensa已经完全连不上&#xff0c;并显示超时&#xff0c;至于之前有传言称他们会恢复服务也完全是无稽之谈。 那么&#xff0c;Leensa停止服务后&#xff0c;广大的外贸人&#xff0c;设计人&#xff0c;留学生以及技术人学习&#xff0c;查资料以及开发客户该怎么办呢&#…...

算法思想之哈希表

欢迎拜访&#xff1a;雾里看山-CSDN博客 本篇主题&#xff1a;算法思想之哈希表 发布时间&#xff1a;2025.4.28 隶属专栏&#xff1a;算法 目录 算法介绍哈希表作用什么时候使用哈希表怎么使用哈希表 例题两数之和题目链接题目描述算法思路代码实现 判定是否互为字符重排题目链…...

springboot 视频分段加载在线播放

页面访问视频资源 前端播放加载部分视频,每次选中一个时间点后 往后加载一部分视频,主要用以节省网络传输的数据量 通过ResourceHttpRequestHandler类实现&#xff0c;ResourceHttpRequestHandler支持分片加载&#xff0c;前端请求头中携带Range: bytes 0-10001&#xff0c;就…...

【题解-Acwing】868. 筛质数

题目:868. 筛质数 题目描述 给定一个正整数 n,请你求出 1∼n 中质数的个数。 输入 共一行,包含整数 n。 输出 共一行,包含一个整数,表示 1∼n 中质数的个数。 数据范围 1 ≤ n ≤ 106 时空限制 0.2s / 64MB 输入样例 8输出样例 4代码 #include...

java 和 C#操作数据库对比

Java和C#在操作数据库方面有诸多相似之处&#xff0c;但也存在一些差异&#xff0c;以下从几个方面为你进行对比&#xff1a; 数据库连接 Java 在Java中&#xff0c;使用JDBC&#xff08;Java Database Connectivity&#xff09;来连接数据库。连接数据库的步骤通常包括加载…...

用 Python打造交互式图片-音视频管理器:代码分析与实践

在 Python 的 GUI 开发领域&#xff0c;wxPython 是一个功能强大且跨平台的框架&#xff0c;适合快速构建桌面应用程序。本文将深入分析一个基于 wxPython 的交互式图片管理器项目&#xff08;SelectModelToPlayVideoAndAudio.py&#xff09;&#xff0c;该程序允许用户管理图片…...

Django 缓存框架

动态网站的一个基本权衡是它们是动态的。每当用户请求页面时&#xff0c;Web 服务器进行各种计算&#xff0c;从数据库查询到模板渲染到业务逻辑&#xff0c;以创建您网站访问者看到的页面。从处理开销的角度来看&#xff0c;这比标准的从文件系统中读取文件的服务器安排要昂贵…...

后缀数组~

子串&#xff1a;在字符串s中&#xff0c;取任意i<j,那么在s中截取从i到j的这一段就叫做s的一个子串。 后缀&#xff1a;后缀就是从字符串的某个位置i到字符串末尾的子串&#xff0c;我们定义以s的第i个字符为第一个元素的后缀为suff(i)。 suff(1)就是从第一个字符到最后一个…...

Rust 学习笔记:编程练习(一)

Rust 学习笔记&#xff1a;编程练习&#xff08;一&#xff09; Rust 学习笔记&#xff1a;编程练习&#xff08;一&#xff09;Convert temperatures between Fahrenheit and CelsiusGenerate the nth Fibonacci numberPrint the lyrics to the Christmas carol “The Twelve …...