高级数据结构:线段树
线段树概述
线段树是一种处理区间问题的优越算法,也是算法竞赛的常客。
线段树的特点是,类似于一棵二叉树,将一个序列分解成多个区间并储存在二叉树上。
例如,把区间 [ 1 , 10 ] [1,10] [1,10]作为树的根节点,然后把 [ 1 , 5 ] [1,5] [1,5]作为左子节点,把 [ 6 , 10 ] [6,10] [6,10]作为右子节点,以此类推,不断扩散。
这种算法的优越之处在于每个节点都储存了某个区间的“特征值”。这个特征值可以是区间和,也可以是区间的最大值最小值。
我们知道,假如给定一个序列,需要求 m m m次区间 [ l , r ] [l,r] [l,r]的和,这个操作的时间复杂度是 O ( m n ) O(mn) O(mn)。在算法竞赛中, m , n > = 1 0 5 m,n>=10^5 m,n>=105的时候这个时间复杂度是不可以接受的。
而二叉树访问某个特定节点的时间复杂度是 O ( l o g n ) O(logn) O(logn),所以用线段树访问并维护区间“特征值”的时候,访问m次的时间复杂度只有 O ( m l o g n ) O(mlogn) O(mlogn),极大降低了时间复杂度
也因此,线段树常常被用于解决某个区间可以被划分成子区间的问题,例如区间和,区间最值。
线段树的构造
接下来,我们看一下如何构造一个线段树。
类似二叉树,我们可以通过动态管理内存构造一棵二叉树,即通过结构体和指针动态分配二叉树的内存,也可以用一个静态数组构造一棵二叉树,在算法竞赛中,常用的是后者,本文也会以后者为示例。读者可以自行探索前一种写法。
正如我们前面所说,线段树需要维护的是区间的一个“特征值”,需要我们把这个特征值在构造线段树的时候计算出来存入,方便后续的调用。
#include<iostream>
#include<vector>
using namespace std;
#define ll long long
const int MAXN = 1e5+10;
ll tree[4*MAXN],a[MAXN];
int n,m;
void build(int index,int left,int right){if(left==right){tree[index]=a[left];return;}int mid = left +(right-left)/2;//闭区间build(2*index,left,mid);//二叉树的左子节点build(2*index+1,mid+1,right);tree[index] = tree[2*index]+tree[2*index+1];//维护部分和,可被替换成其他区间的特征return;
}
大致解释一下,假如我们给一棵满二叉树的节点从上到下、从左到右按顺序编号,那么节点 k k k的左子节点必然是 2 k 2k 2k,右子节点必然是 2 k + 1 2k+1 2k+1,这可以从数列的规律得到,在此不多阐述。
上面的代码就是通过递归,实现了先构造底层的区间和,上层节点直接把左区间和右区间的区间和加起来就得到了自己的区间和。
区间查询函数 query()
现在,我们已经知道一棵线段树如何构造了。
那么假如任务要求查询区间 [ l b , r b ] [lb,rb] [lb,rb]的区间和,我们如何利用这棵线段树查询呢?
查询操作与构造类似,通过递归来计算区间[lb,rb]下有几个节点。
ll query(int index,int leftBound,int rightBound,int left,int right){//leftBound和rightBound是想要查询的区间if(leftBound <= left&&rightBound>=right){return tree[index];}//完全包括目前区间,可以直接返回int mid = left +(right-left)/2;//闭区间ll res=0;if(leftBound<=mid){//左子节点和目标区间有重叠res+= query(index<<1,leftBound,rightBound,left,mid);}if(mid+1<=rightBound){//右子节点和目标区间有重叠res+= query(index<<1|1,leftBound,rightBound,mid+1,right);}return res;
}调用:
query(1,l,r,1,n);
递归中,初始的区间必然大于等于查询区间,进入递归。
递归过程中有4种情况,一种是目前区间(A)在查询区间(B)内部,这种情况直接返回答案。
还有三种情况分别是A与B相交,A包含了B以及A与B互斥。
当AB互斥时,A与B无联系,不进入递归。
当A和B有重复的时候,A的某一个或几个子节点必然是在B内部的,因为A可以被拆分直到只剩一个元素。
所以我们要做的就是递归找到在B内部的A子节点,然后加入答案之中。
区间修改与懒标记(Lazy-Tag)
Lazy-Tag概述
试想,如果我们需要修改线段树上面的一个节点,时间复杂度是多少?
是O(logn),因为不仅需要修改这个节点,还需要修改这个节点的前驱全部节点(通过递归实现)
假如同时给一个区间[l,r]加10呢?那时间复杂度就取决于区间长度m,时间复杂度为O(mlogn)
这是不可忍受的时间复杂度,因为我们往往可能进行多次区间修改,总的时间复杂度会达到O(n^2logn)
Lazy-Tag就是解决这个问题的精妙构思。线段树的节点表示了这个区间的某个特征值,假如我们需要对这个区间整体操作,那么这个操作就可以被映射到特征值上面,而不必修改区间中的每个元素。
那么“懒”在哪?懒就懒在我们对根节点更新后,不必更新子节点,而是在下次递归的时候“顺路”把访问到的子节点更新了。它的本质是搭“顺风车”,这种思想并不少见,在效率最高的筛选素数方法:欧拉筛中,也是在循环中利用“搭顺风车”的办法减少时间复杂度。
总的来说,Lazy-Tag就是用一个tag[]数组,标记某个tree的节点需要被更新,并且在做其他操作,例如查询的时候顺便更新,减少时间复杂度。
区间修改
具体的修改思路是,对于给定的区间[l,r]的修改,先类似于查询,找出所有包含于[l,r]的节点,并且更新这些节点,再通过递归更新节点的上层节点。
这个过程中,我们并不关心区间[l,r]中的节点是否有子节点。例如, [3,5]在我们想要修改的区间[1,5]中,但我们不去修改[3,5]的子节点,因为那是懒标记做的事情
void push_down(int index,int left,int right){//需要“分家”了,把标签传给两个儿子if(tag[index]){int mid = left +(right-left)/2;int ls=index*2,rs=index*2+1;tag[ls]+=tag[index],tag[rs]+=tag[index];tree[ls]+=(mid-left+1)*tag[index],tree[rs]+=(right-mid)*tag[index];tag[index]=0;}
}
void update(int index,int leftBound,int rightBound,int left,int right,ll value){if(leftBound <= left&&rightBound>=right){//完全包括目前区间tree[index]+= (right-left+1)*value;tag[index]+=value;//这里的意思是,index节点被更新过了,值储存在tag内,当区间中部分点想要变化的时候就“分家”return;}//无法整体操作,需要拆分区间了push_down(index,left,right);int mid = left +(right-left)/2;//闭区间ll res=0;if(leftBound<=mid)//左子节点和目标区间有重叠update(2*index,leftBound,rightBound,left,mid,value);if(mid+1<=rightBound)//右子节点和目标区间有重叠update(2*index+1,leftBound,rightBound,mid+1,right,value);tree[index] = tree[index*2]+tree[index*2+1];//子节点更新了,父节点跟着更新return;
}
这里的 t a g [ i n d e x ] tag[index] tag[index]表示已经对节点 i n d e x index index修改过了,但是没有修改子节点
模板题
让我们通过一个模板题目把上面学到的知识串联起来吧。
P3372 【模板】线段树 1
#include<iostream>
#include<vector>
using namespace std;
#define ll long long
const int MAXN = 1e5+10;
ll tree[4*MAXN],a[MAXN],tag[4*MAXN];
int n,m;
void build(int index,int left,int right){if(left==right){tree[index]=a[left];return;}int mid = left +(right-left)/2;//闭区间build(2*index,left,mid);//二叉树的左子节点build(2*index+1,mid+1,right);tree[index] = tree[2*index]+tree[2*index+1];//维护部分和,可被替换成其他区间的特征return;
}
void push_down(int index,int left,int right){//需要“分家”了,把标签传给两个儿子if(tag[index]){int mid = left +(right-left)/2;int ls=index*2,rs=index*2+1;tag[ls]+=tag[index],tag[rs]+=tag[index];tree[ls]+=(mid-left+1)*tag[index],tree[rs]+=(right-mid)*tag[index];tag[index]=0;}
}void update(int index,int leftBound,int rightBound,int left,int right,ll value){if(leftBound <= left&&rightBound>=right){//完全包括目前区间tree[index]+= (right-left+1)*value;tag[index]+=value;//这里的意思是,index节点被更新过了,值储存在tag内,当区间中部分点想要变化的时候就“分家”return;}//无法整体操作,需要拆分区间了push_down(index,left,right);int mid = left +(right-left)/2;//闭区间ll res=0;if(leftBound<=mid)//左子节点和目标区间有重叠update(2*index,leftBound,rightBound,left,mid,value);if(mid+1<=rightBound)//右子节点和目标区间有重叠update(2*index+1,leftBound,rightBound,mid+1,right,value);tree[index] = tree[index*2]+tree[index*2+1];//子节点更新了,父节点跟着更新return;
}ll query(int index,int leftBound,int rightBound,int left,int right){//leftBound和rightBound是想要查询的区间if(leftBound <= left&&rightBound>=right){return tree[index];}//完全包括目前区间,可以直接返回//不能覆盖push_down(index,left,right);int mid = left +(right-left)/2;//闭区间ll res=0;if(leftBound<=mid){//左子节点和目标区间有重叠res+= query(index<<1,leftBound,rightBound,left,mid);}if(mid+1<=rightBound){//右子节点和目标区间有重叠res+= query(index<<1|1,leftBound,rightBound,mid+1,right);}return res;
}int main(){cin>>n>>m;for(int i=1;i<=n;i++)cin>>a[i];build(1,1,n);for(int i=0;i<m;i++){int op;cin>>op;if(op==2){int l,r;cin>>l>>r;cout<<query(1,l,r,1,n)<<endl;}else{int l,r;long long val;cin>>l>>r>>val;update(1,l,r,1,n,val);}}return 0;
}
补充练习
hdu 4027-Can you answer these queries?
hdu 4578-Transformation
相关文章:
高级数据结构:线段树
线段树概述 线段树是一种处理区间问题的优越算法,也是算法竞赛的常客。 线段树的特点是,类似于一棵二叉树,将一个序列分解成多个区间并储存在二叉树上。 例如,把区间 [ 1 , 10 ] [1,10] [1,10]作为树的根节点,然后把…...
精讲C++四大核心特性:内联函数加速原理、auto智能推导、范围for循环与空指针进阶
前引:在C语言长达三十余年的演进历程中,每一次标准更新都在试图平衡性能与抽象、控制与安全之间的微妙关系。从C11引入的"现代C"范式开始,开发者得以在保留底层控制能力的同时,借助语言特性大幅提升代码的可维护性与安全…...
用ffmpeg压缩视频参数建议
注意:代码中的斜杠\可以删除 一、基础压缩命令(画质优先) ffmpeg -i input.mp4 \-c:v libx264 -preset slow -crf 23 \ # H.264编码,平衡速度与质量-c:a aac -b:a 128k \ # 音频压缩-vf "scaleif(gt(a,16/9),1920,-2):if(…...
uni-app学习笔记(二)--vue页面代码的构成和新建页面
vue页面的构成 一.template 模板区,主要放html布局,注意,如果是开发uni-app,模板区不要放div,h1等标签了,用了在小程序和app端起不到作用。具体应该使用哪些组件,可在uni-app官网上查看:组件-…...
机器语言程序、汇编语言程序、硬件描述语言程序、编译程序、解释程序和链接程序
程序类型定义与核心特征处理对象 / 输入输出结果所属领域典型例子 / 作用机器语言程序由二进制指令(0/1 序列)构成,可被 CPU 直接执行,与硬件架构强绑定。无(直接执行)无(直接运行)低…...
智能语音助手的未来:从交互到融合
摘要 随着人工智能技术的不断进步,智能语音助手已经成为我们生活中不可或缺的一部分。从简单的语音指令到复杂的多模态交互,语音助手正在经历一场深刻的变革。本文将探讨智能语音助手的发展历程、当前的技术瓶颈以及未来的发展方向,特别是其在…...
Redis从基础到高阶应用:核心命令解析与延迟队列、事务消息实战设计
Redis基础知识 #切换数据库 bd:0>select 2 "OK" bd:2>dbsize "0" #清空数据库 bd:0>flushdb "OK" #设置值 bd:0>set name "lyt" "OK" #查看所有key bd:0>keys *1) "name" #获取key bd:0>get …...
操作系统原理实验报告
操作系统原理课程的实验报告汇总 实验三:线程的创建与撤销 实验环境:计算机一台,内装有VC、office等软件 实验日期:2024.4.11 实验要求: 1.理解:Windows系统调用的基本概念,进程与线程的基…...
Python爬虫实战:研究nodejs aes加密
1. 引言 1.1 研究背景与意义 在当今数字化时代,Web 数据的价值日益凸显。通过爬虫技术获取公开数据并进行分析,能够为企业决策、学术研究等提供有力支持。然而,为了保护数据安全和隐私,许多网站采用了加密技术对数据进行保护,其中 AES 加密是一种常见且安全的加密算法。…...
线程的一些事(2)
在java中,线程的终止,是一种“软性”操作,必须要对应的线程配合,才能把终止落实下去 然而,系统原生的api其实还提供了,强制终止线程的操作,无论线程执行到哪,都能强行把这个线程干掉…...
基于 PostgreSQL 的 ABP vNext + ShardingCore 分库分表实战
🚀 基于 PostgreSQL 的 ABP vNext ShardingCore 分库分表实战 📑 目录 🚀 基于 PostgreSQL 的 ABP vNext ShardingCore 分库分表实战✨ 背景介绍🧱 技术选型🛠️ 环境准备✅ Docker Compose(多库 & 读…...
御网杯2025 Web,Msic,密码 WP
Web YWB_Web_xff 审计代码,发现需要$cip2.2.2.1 使用burpsuite抓包,添加X-Forwarded-For:2.2.2.1 然后得到flag YWB_Web_未授权访问 更加题目描述知道需要admin登录,但是现在是guest。 使用burpsuite抓包 发现cookie里面存在userÿ…...
tensorflow 1.x
简介 TensorFlow:2015年谷歌,支持python、C,底层是C,主要用python。支持CNN、RNN等算法,分CPU TensorFlow/GPU TensorFlow。 TensorBoard:训练中的可视化。 快捷键:shiftenter执行命令,Tab键进…...
[ERTS2012] 航天器星载软件形式化模型驱动研发 —— 对 Scade 语言本身的影响
在《从ERTS学习SCADE发展》中提到,在 ERTS 会议中,Scade团队会在该会议中介绍与Scade相关的工作。在 ERTS 2012 中,Scade 团队介绍了使用Scade作为主要工具,应用在航天器星载软件开发中的相关话题。原材料可参考 《Formal Model D…...
Spring Boot 集成 Flink CDC 实现 MySQL 到 Kafka 实时同步
Spring Boot 集成 Flink CDC 实现 MySQL 到 Kafka 实时同步 📌 项目背景 在大数据实时处理场景中,数据库变更数据的捕获与传输是关键环节。Flink CDC 提供了从 MySQL 等数据库中实时捕获数据变更的能力,并通过 Apache Flink 引擎实现流式处理。 本项目使用 Spring Boot …...
软件体系结构(Software Architecture)
文章目录 1. 分层架构(Layered Architecture)核心逻辑代码示例(伪代码)典型场景优缺点 2. 客户端-服务器(Client-Server)核心逻辑典型交互流程应用场景代码示例(RESTful API)优缺点 …...
RS485和RS232 通信配置
RS232 目前硬件上支持RS232的有以下板卡: LubanCat-5IO底板(含有RS232x2) 7.1. 引脚定义 具体的引脚定义可以参考背面的丝印 LubanCat-5IO底板 引脚定义图 7.2. 跳帽配置 LubanCat-5IO底板 鲁班买5IO底板上的RS485和RS232是共用同一组…...
【高数上册笔记篇02】:数列与函数极限
【参考资料】 同济大学《高等数学》教材樊顺厚老师B站《高等数学精讲》系列课程 (注:本笔记为个人数学复习资料,旨在通过系统化整理替代厚重教材,便于随时查阅与巩固知识要点) 仅用于个人数学复习,因为课…...
【网络安全】——大端序(Big-Endian)和小端序(Little-Endian)
字节序(Endianness)是计算机系统中多字节数据(如整数、浮点数)在内存中存储或传输时,字节排列顺序的规则。它分为两种类型:大端序(Big-Endian)和小端序…...
机器学习极简入门:从基础概念到行业应用
有监督学习(supervised learning) 让模型学习的数据包含正确答案(标签)的方法,最终模型可以对无标签的数据进行正确处理和预测,可以分为分类与回归两大类 分类问题主要是为了“尽可能分开整个数据而画线”…...
MIT XV6 - 1.5 Lab: Xv6 and Unix utilities - xargs
接上文 MIT XV6 - 1.4 Lab: Xv6 and Unix utilities - find xargs 继续实验,实验介绍和要求如下 (原文链接 译文链接) : Write a simple version of the UNIX xargs program for xv6: its arguments describe a command to run, it reads lines from the standard …...
Springboot整合Swagger3
Springboot整合Swagger3、常用注解解释、访问Swagger地址出现404、403、拒绝访问等问题_swagger3注解-CSDN博客...
经典音乐播放器——完美歌词 Poweramp Music Player 3 build
—————【下 载 地 址】——————— 【本章单下载】:https://drive.uc.cn/s/d6c480bc47604 【百款黑科技】:https://ucnygalh6wle.feishu.cn/wiki/HPQywvPc7iLZu1k0ODFcWMt2n0d?fromfrom_copylink —————【下 载 地 址】——————— 本…...
锚定基础与拥抱融合:C 语言在编程教育与技术社区的破圈之路
引言 在 Python 占据 TIOBE 指数榜首的 2025 年,C 语言以 23.4% 的稳定份额(2025 年 5 月数据)持续稳居前三,这一现象在编程教育领域尤为显著:全球 92% 的计算机科学本科课程仍将 C 语言作为必修基础课,而…...
深度学习入门:从神经网络基础到前向传播全面解析
深度学习入门:从神经网络基础到前向传播全面解析 🔥 重磅干货! 本文是《深度学习基础与核心技术详解》专栏的开篇之作,将系统性地带你走进深度学习的世界!建议收藏+关注,错过可能要找很久哦~ 目录 深度学习概述神经网络基础 2.1 生物神经元与人工神经元2.2 感知机模型2.…...
Lambda表达式能用在哪些场景?
Lambda表达式是Java 8引入的一种强大特性,它允许以简洁的方式表示匿名函数(即没有名字的函数)。Lambda表达式可以用于许多场景,尤其是在与函数式接口、Stream API、并发编程等结合时,能够显著简化代码并提高开发效率。…...
英语听力口语词汇--2.宣传类
1.approach uk /əˈprəʊtʃ/ n.(思考问题的)方式,方法,态度 2.foreign uk /ˈfɒr.ən/ adj.外国的 3.alliance uk /əˈlaɪ.əns/ n.结盟国家(或团体),同盟国家(或团体)&...
『 测试 』测试基础
文章目录 1. 调试与测试的区别2. 开发过程中的需求3. 开发模型3.1 软件的生命周期3.2 瀑布模型3.2.1 瀑布模型的特点/缺点 3.3 螺旋模型3.3.1 螺旋模型的特点/缺点 3.4 增量模型与迭代模型3.5 敏捷模型3.5.1 Scrum模型3.5.2 敏捷模型中的测试 4 测试模型4.1 V模型4.2 W模型(双V…...
Pandas 时间处理利器:to_datetime() 与 Timestamp() 深度解析
Pandas 时间处理利器:to_datetime() 与 Timestamp() 深度解析 在数据分析和处理中,时间序列数据扮演着至关重要的角色。Pandas 库凭借其强大的时间序列处理能力,成为 Python 数据分析领域的佼佼者。其中,to_datetime() 函数和 Ti…...
支持向量机的回归用法详解
支持向量机的回归用法详解 在机器学习的广阔领域中,支持向量机(SVM)是一种极具影响力的算法,它不仅在分类任务上表现出色,在回归任务中同样有着独特的应用价值。本文将深入探讨 SVM 的回归用法,包括其基本…...
计算机基础
今天不和大家分享算法了,最近为什么一直分享算法题,一个是因为最近很忙加上状态不太在线,第二个是因为我报了ICPC的比赛,也就是大学生程序设计大赛,所以平时刷算法比较多一些,虽然说结果上也没有很多的收获…...
用C语言实现的——一个支持完整增删查改功能的二叉排序树BST管理系统,通过控制台实现用户与数据结构的交互操作。
一、知识回顾 二叉排序树(Binary Search Tree,BST),又称二叉查找树或二叉搜索树,是一种特殊的二叉树数据结构。 基本性质: ①有序性 对于树中的每个节点,其左子树中所有节点的值都小于该节点的…...
uniapp-商城-53-后台 商家信息(更新修改和深浅copy)
1、概述 文章主要讨论了在数据库管理中如何处理用户上传和修改商家信息的问题,特别是通过深浅拷贝技术来确保数据更新的准确性和安全性。 首先,解释了深拷贝和浅拷贝的区别:浅拷贝使得两个变量共享相同的内存地址,而深拷贝则创建新…...
vue数据可视化开发echarts等组件、插件的使用及建议-浅看一下就行
在 Vue 项目中使用 ECharts 进行数据可视化开发时,可以结合 Vue 的响应式特性和 ECharts 的强大功能,实现动态、交互式的图表展示。 一、ECharts 基础使用 1. 安装 ECharts npm install echarts2. 在 Vue 组件中使用 ECharts <template><div…...
百度AI战略解析:文心一言与自动驾驶的双轮驱动
百度AI战略解析:文心一言与自动驾驶的双轮驱动 系统化学习人工智能网站(收藏):https://www.captainbed.cn/flu 文章目录 百度AI战略解析:文心一言与自动驾驶的双轮驱动摘要引言一、技术架构:大模型与自动…...
MCP Streamable HTTP 传输层的深度解析及实战分析
一、Streamable HTTP 传输层设计革新 1. 核心设计思想 协议融合:将 HTTP/1.1、HTTP/2 与 SSE 协议特性深度整合动态协商:通过 HTTP Header 实现传输协议动态协商(X-MCP-Transport)流式优先:默认启用流式传输,支持半双工通信背压控制:基于 HTTP/2 流级流量控制实现智能速…...
六大设计模式--OCP(开闭原则):构建可扩展软件的基石
写在前面:一个真实的项目悲剧 某电商平台促销功能每次迭代都需要修改核心订单类,导致: ✅ 双十一活动修改导致支付功能崩溃 ✅ 新人优惠引发会员系统连环故障 ✅ 每次发布需全量回归测试 根本原因:系统架构违反开闭原则 一、开闭…...
ActiveMQ 生产环境问题排查与调优指南(一)
一、引言 在当今复杂的分布式系统架构中,消息中间件扮演着至关重要的角色,而 ActiveMQ 作为一款广泛使用的开源消息中间件,凭借其丰富的特性、良好的稳定性和易用性,在众多企业的生产环境中占据了一席之地。它基于 JMS(…...
深入理解 JavaScript 中的 FileReader API:从理论到实践
文章目录 深入理解 JavaScript 中的 FileReader API:从理论到实践前言什么是 FileReader?核心特性 FileReader 的常用方法事件监听实际案例案例 1:读取文本文件内容案例 2:图片预览(Data URL)案例 3&#x…...
Google LLM prompt engineering(谷歌提示词工程指南)
文章目录 基本概念AI输出配置:调整AI的回答方式输出长度温度(Temperature)Top-K和Top-P 提示技术:让AI更好地理解你零样本提示(Zero-shot)少样本提示(Few-shot)系统提示(…...
前端npm包发布流程:从准备到上线的完整指南
无论是使用第三方库还是创建和分享自己的工具,npm都为我们提供了一个强大而便捷的平台,然而很多开发者在将自己的代码发布到npm上时往往面临各种困惑和挑战,本篇文章将从准备工作到发布上线,探讨如何让npm包更易发布及避免常见的坑…...
【MySQL】表空间结构 - 从何为表空间到段页详解
📢博客主页:https://blog.csdn.net/2301_779549673 📢博客仓库:https://gitee.com/JohnKingW/linux_test/tree/master/lesson 📢欢迎点赞 👍 收藏 ⭐留言 📝 如有错误敬请指正! &…...
OB Cloud 云数据库V4.3:SQL +AI全新体验
OB Cloud 云数据库V4.3:SQL AI全新体验 简介 OB Cloud云数据库全新升级至V4.3版本,为用户带来了SQLAI的最新技术体验,强化数据库的传统功能,深度融合了人工智能技术,引入先进的向量检索功能和优化的SQL引擎,…...
【Linux系统】第四节—详解yum+vim
hello 我是云边有个稻草人 Linux—本节课所属专栏—欢迎订阅—持续更新中~ 目录 画板—本节课知识点详解 一、软件包管理器 1.1 什么是软件包 1.2 Linux软件⽣态 1.3 yum具体操作 【查看软件包】 【安装软件】 【卸载软件】 【注意事项】 1.4 安装源 二、vim 2.1 …...
Git的核心作用详解
一、版本控制与历史追溯 Git作为分布式版本控制系统,其核心作用是记录代码的每一次修改,形成完整的历史记录。通过快照机制,Git会保存每次提交时所有文件的完整状态(而非仅记录差异),确保开发者可以随时回…...
Three.js + React 实战系列 - 职业经历区实现解析 Experience 组件✨(互动动作 + 3D 角色 + 点击切换动画)
对个人主页设计和实现感兴趣的朋友可以订阅我的专栏哦!!谢谢大家!!! 在这篇博客中,我们将分析一个极其有趣和互动性的组件 - Experience.jsx,该组件用于在主页中呈现个人的工作经历。 这个组件…...
3D虚拟工厂vue3+three.js
1、在线体验 3D虚拟工厂在线体验 2、功能介绍 1. 全屏显示功能2. 镜头重置功能3. 企业概况信息模块4. 标签隐藏/显示功能5. 模型自动旋转功能6. 办公楼分层分解展示7. 白天/夜晚 切换8. 场景资源预加载功能9. 晴天/雨天/雾天10. 无人机视角模式11. 行人漫游视角模式12. 键盘…...
[Java实战]Spring Boot 解决跨域问题(十四)
[Java实战]Spring Boot 解决跨域问题(十四) 一、CORS 问题背景 什么是跨域问题? 当浏览器通过 JavaScript 发起跨域请求(不同协议、域名、端口)时,会触发同源策略限制,导致请求被拦截。 示例场…...
嵌入式硬件篇---CAN
文章目录 前言1. CAN协议基础1.1 物理层特性差分信号线终端电阻通信速率总线拓扑 1.2 帧类型1.3 数据帧格式 2. STM32F103RCT6的CAN硬件配置2.1 硬件连接2.2 CubeMX配置启用CAN1模式波特率引脚分配过滤器配置(可选) 3. HAL库代码实现3.1 CAN初始化3.2 发…...
(2025)图文解锁RAG从原理到代码实操,代码保证可运行
什么是RAG RAG(检索增强生成)是一种将语言模型与可搜索知识库结合的方法,主要包含以下关键步骤: 数据预处理 加载:从不同格式(PDF、Markdown等)中提取文本分块:将长文本分割成短序列(通常100-500个标记),作为检索单元…...