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

图 最 短 路

Diikstra朴素

  1. 非负边权
  2. 单源最短路
  3. 顶点数最好小于1000
  4. 少量数据结构知识和一点点的算法基础
算法描述

这个算法我们采用邻接矩阵来存储,有时候输入数据,并不是我们期待的那样,所以需要对数据做一些处理,也就是把图创建起来的过程。

对于图 G=<V,E>,源点为 s,dist[i] 这个数组表示 s 到i的最短路,visited[i] 表示 dist[i] 是否已经确定(布尔值),即s到i的最短路是否已经确定。

第三步、初始化
初始化所有顶点的数据如下:dist[i] = 正无穷 (0≤i<n)      visited[i] = false(0≤i<n)       那么原点到原点的dist[s] = 0

第四步、找距离最小的点
从所有visited[i]为false的没有被访问过的顶点中找到一个 dist[i] 值最小的,令x=i,并且标记 visited[x] 为 true; 如果找不到,算法结束;

第五步、更新其余点的距离

更新从× 出发的,到达顶点y的最短路dist[y]:         dist[y]=min(dist[y], dist[x]+w(x,y))

第六步、重复执行
回到第四步,继续找距离最小值

算法图解

从原点到原点的路径一定是0,那么0的dist就是0标记完了后我们访问true,更新其余点的距离,那么1 2 3的dist 是1 4 10,接下来找到其中最小的点,是1,那么1就true

 继续从1看,只有2联通,且此时距离4>3,2的dist更新为3,第二轮结束;接下来继续找距离最小的点

代码分析
第一步、初始化邻接矩阵
function initEdges(graph, n)for u -> (0, n-1)for v -> (0, n-1)graph[u][v] = inf
第二步、边的添加
function addEdge(graph, u, v, w)graph[u][v] = min(graph[u][v], w)直接赋值处理不了u到v的情况
第三步、建图
根据题目给出的数据,调用addEdge逐渐完善起来
addEdge(graph, u1, v1, w1)
addEdge(graph, u2, v2, w2)
addEdge(graph, uk, vk, wk)
第四步、框架代码
function Dijkstra(graph, n, s, dist)visited[]//定义一个dijk数组DijkstraInit(n, S, visited, dist)while trueu = DijkstraFindMin(n, visited, dist)//min的值if u == -1 return DijkstraUpdate(graph, n, u, visited, dist)//
第五步、Dijkstra 初始化
function DijkstraInit(n, s, visited, dist)for i -> (0, n-1)visited[i] = falsedist[i] = inf //无穷大dist[s] = 0 //为了s出发,到s的距离变成最短路径
第六步、Dijkstra找最小距离
function DijkstraFindMin(n, visited, dist)u=-1for i -> (0, n-1)if visited[i] conintuneif u == -1 or dist[i] < dist[u]u=ireturn u
第七步、Dijkstra 更新
function DijkstraUpdate(graph, n, u, visited, dist)visited[u] = true //防止找到原点for i -> (0, n-1)if visited[i] continuedist[i] = min(dist[i], dist[u] + graph[u][i]) //所有过程中到s的最短路径,//和从u过来的最短路径取小者
细节剖析

Bellman-Ford

Bellman-Ford算法特点,时间复杂度是O(NM)

  1. 可求负边权
  2. 单源最短路
  3. 顶点数×边数最好小于1000000
  4. 少量数据结构知识和一点点的算法基础

问题描述
在一个n(n≤500)个顶点和m(m≤2000)条边的连通图上,边有两种类型,种是正常的路;一种是虫洞。正常的路是双向的,行走时花费时间;虫洞是单向的,行走时能让时间倒退。问是否存在某个点出发,并且在过去的某个时间回到该点。

抽象一下: 1、如果没有虫洞,这就是一个无向连通图。也就是说任意两点间可达,那么加入虫洞以后,还是任意两点间可达的。2、只要存在一个负权圈,就可以利用这个负权圈,把时间无限往前推,也就可以实现时光倒流。

 问题抽象
求一个任意两点间可达的连通图,是否存在一个负权圈?                ---------------------什么是负权圈?比如1---2, 2----3 ,3----1,这么一个圈子 , 使得经过该环的路径权重之和为负值

Bellman-Ford算法可以在最短路存在的情况下求出最短路,并且能够判断图中是否存在负权圈。

算法原理:Bellman-Ford算法是基于这样一个事实:一个图的最短路如果存在,那么最短路中必定不存在负权圈,所以最短路的顶点数除了起点外最多只有n-1 个。Bellman-Ford同样也是利用了最短路的最优子结构性质,用d[j表示起点s到i的最短路,那么边数上限为j的最短路可以通过边数上限为j-1的最短路加入一条边得到,通过n-1次迭代,最后求得s到所有点的最短路。

对于图G=<V,E>,源点为s,d[i] 表示s到i的最短路。
(1)初始化所有顶点d[i]=inf,令d[s]=0,计数器c=0;
(2) 枚举每条边 w(u, v),如果 d[u] ≠ inf,则更新:d[v] = min(d[v], d[u] + w(u, v) )(这一步叫“松弛”操作)
(3)计数器c自增1,当c==n-1时算法结束,否则继续 重复(2)的步骤;

这个算法并没有考虑到负权圈的问题,如果存在负圈权,那么第(2)步操作的更新会永无止境,所以判定负权圈的算法也就出来了,只需要在第n次继续进行第 (2)步的松弛操作,如果有至少一条边能够被更新,那么必定存在负权圈。

代码分析:
第一步、定义边的数据结构
Edge(u, v, w)第二步、边的添加
function addEdge(edges, u, v, w)edges.append( Edge(u, v, w))
第三步、建图
根据题目给出的数据,调用addEdge
addEdge(edges, u1, v1, w1)
addEdge(edges, u2, v2, w2)
addEdge(edges, uk, vk, wk)
第四步、实现松弛操作
function doRelax(edges, d[maxn])isRelax = Falsefor i -> (0, edges.size()-1)u, v, w = edges[i]if d[u] + w < d[v]d[v] = d[u] + wisRelax = Truereturn isRelax
第五步、算法核心
function bellman(n, s, edges, d[maxn])for i -> (0, n-1)d[i] = infd[s] = 0for i -> (1, n-1)if not doRelax(edges, d)return falsereturn doRelax(edges, d)

Floyd

  1. 属于动态规划
  2. 全源最短路
  3. 顶点数最好小于100
  4. 少量数据结构知识和一点点的算法基础

 问题描述
对于一个n(n≤ 100)个顶点的有向图(顶点编号是0到n-1),给定一些顶点之间的边 e(u,V, w),求任意两点之间的最短路。

朴素算法  :   枚举每个点作为起点,求n 次 Dijkstra。时间复杂度就是O(n^3)

第一步、设计状态
令d[k][j][j]为只允许经过结点[0,k)作为中间点的情况下,i到j的最短路。左闭右开,那么左闭右开的节点,那么当k==0的时候,不经过任何节点,,k==1的时候经过0,k==2就是 0 1.依次入场................

第二步、初始状态
d[0][j][j] 代表只经过[0,0],也就是不经过任何中间点。

 第三步、状态转移
令 d[k][j][j] 为只允许经过结点[0,k)作为中间点的情况下,i到j的最短路。
【不包含k】如果最短路不经过k点,则:d[k][i][j] = d[k-1][i][j],实际上就是不经过就是0到k-1的
【包含k】如果最短路经过k点,则: d[k][j][j] = d[k-1][i][k] + d[k-1][k][j]

 第四步、状态转移方程

 第五步、空间优化

d[j][j] = min(d[i][j], d[i][k] + d[k][j])         (0≤i,j<n,1≤k≤n)

第一步、初始化邻接矩阵
function initEdges(graph, n)for u -> (0, n-1)for v -> (0, n-1)if u ==vgraph[u][v] = 0elsegraph[u][v] = inf
第二步、边的添加
function addEdge(graph, u, v, w)graph[u][v] = min(graph[u][v], w)
第三步、建图
根据题目给出的数据,调用addEdge
addEdge(graph, u1, v1, w1)
addEdge(graph, u2, v2, w2)
addEdge(graph, uk, vk, wk)
第四步、框架代码
function Floyd(graph, n, s, dist)for k -> (0, n-1)for i -> (0, n-1)for j-> (0, n-1)graph[i][j] = min(graph[i][j], graph[i][k] + graph[k][j])

细节剖析
for k -> (0, n-1) //重中之重,k一定在第一层for i -> (0, n-1)for j -> (0, n-1)

Dijkstra + Heap

  1. 非负边权
  2. 单源最短路
  3. 顶点数、边数<1000000
  4. 数据结构前置:邻接表、哈希表、二叉堆

 问题描述
给定一张n(n≤10000)个顶点以及m(m≤100000)条边的有向图,顶点编号从0到n-1,该图可以有自环与重边。
求输出0号点到其它所有点的最短路,若不存在此最短路,则最短路的值为-1。

 第一步、建图
任何算法我们都要去思考,用什么数据结构来存储,这个算法我们采用邻接表来存储,有时候输入数据,并不是我们期待的那样,所以需要对数据做一些处理,也就是把图创建起来的过程。

第二步、辅助数组
对于图 G=<V,E>,源点为 s,dist[i] 表示 s到i的最短路,visited[i] 表示 dist[i]是否已经确定(布尔值),即s到i的最短路是否已经确定。 

 第三步、辅助堆
利用一个小顶堆heap存放二元组(v,dist[v]),小顶堆扮演的是优先队列的作用,dist[v]值越小的,会从优先队列中优先出队。

第四步、初始化
初始化所有顶点的数据如下:
dist[i] =无穷大            (0≤i<n)
visited[i] = false         (i<n)
dist[s] = 0
heap.push( (s, dist[s]) )  不能只插入顶点,距离原点最近,也不能只插入最近距离,因为最近距离无法反馈顶点编号的,我们需要顶点编号

 第五步、找距离最小的点
从小顶堆中不断弹出元素u,并且判断visited[u]是否为 true,如果为 true,则继续弹出;否则标记为true,并且从u出发进行"松弛”操作;如果堆为空,算法结束;

第一步、定义距离二元组
Dist(v, w)
第二步、初始化邻接表
function initEdges(n, edges[maxn])for i -> (0, n-1)edges[i] = {}
第三步、邻接表加边
function addEdge(edges[maxn], u, v, w)edges[u].append( Dist(v, w) )
第四步、建图
根据题目给出的数据,调用addEdge
addEdge(edges, u1, v1, w1)
addEdge(edges, u2, v2, w2)
addEdge(edges, uk, vk, wk)
第五步、框架代码
function DijkstraHeap(n, st, edges[maxn], d[maxn])//程序调用大写的,而自己手动调用小写的dijkheap = Heap()visited[maxn] = {false}dijkstraInit(n, st, heap, visited, d)while( not heap.empty())u = dijkstraFindMin(heap)dijkstraUpdate(u,edges,heap,visited,d)
第六步、初始化
function dijkstraInit(n, st, heap, visited[maxn], d[maxn])for i -> (0, n-1)d[i] = infvisited[i] = falsed[st] = 0heap.push( Dist(st, d[st]))第七步、获取最小值
function dijkstraFindMin(heap)s = heap.top()heap.popOreturn s.v
第八步、松弛操作
function dijkstraUpdate(u, edges[maxn], heap, visited[maxn], d[maxn])if not visited[u]visited[u] = truefor i -> (0, edges[u].size()-1)v = edges[u][i].vw = edges[u][i].wif( d[u] + w < d[v] )d[v] = d[u] + w heap.push( Dist(v, d[v]) )

 第一点、极大值
inf是一个极大值,也就是必须比可能的最长路的的最大值还要大,也就是:

                                                点数n×最大的边权wMax

否则在进行松弛操作的时候,逻辑就错了。就好比线性枚举的时候,求最小值,要先定义一个比所有数据集元素都要大的值一样的道理。

第二点、邻接表存储
之所以用邻接表存储,是因为点数超过1000以后,如果用邻接矩阵存储,内存吃不消,当时时间更吃不消。所以一般如果是用Dijkstra+Heap优化的时候,统一采用邻接表存储。


第三点、堆的作用
对比朴素的利用邻接矩阵存储的Dijkstra,加上堆的作用主要在于,原本需要遍历才能
获取距离dist[u]最小的点u,可以用堆通过O(logn)的时间,快速获取这个最小值对应的)顶点u。


第四点、辅助哈希表
visited[]虽然一般用数组实现,但是实际上是一个哈希表的作用,利用下标的快速插入和查找的特性,能够快速获取一个顶点的最短路是否已经被计算出来。

SPFA

在一个n(n≤10000)个顶点和m(m≤10000)条边的连通图上,边有两种类型,一种是正常的路;一种是虫洞。正常的路是双向的,行走时花费时间;虫洞是单向的,行走时能让时间倒退。问是否存在某个点出发,并且在过去的某个时间回到该点。

 这个问题我们在学习Bellman算法的时候见到过,只不过现在n和m的数据范围大了很多,如果还是采用传统的Bellman算法来求解,最坏情况下肯定是会超时的,所以我们引入一种新的算法SPFA(Shortest Path Faster Algorithm)。

算法描述
对于图G=<V,E>,源点为s,d[i]表示s到i的最短路。

(1)利用一个先进先出的队列用来保存待松弛的结点,每次取出队首结点u,并且枚举从u出发的所有边(u,v),进行松弛操作:
d[v] = min(d[v], d[u] + w(u, v) )
(2)然后判断V点在不在队列中,如果不在就将V点放入队列。这样不断从队列中取出结点来进行松弛操作,直至队列空为止。

第一步、定义边的数据结构
Edge(v, w)
edges0代表以0为起点的邻接表,所有出边的集合;edges1相应的是1出边的集合
第二步、边的添加
function addEdge(edges[maxn], u, v, w)edges[u].append( Edge(v, w) )
第三步、建图
根据题目给出的数据,调用addEdge
addEdge(edges, u1, v1, w1)
addEdge(edges, u2, v2, w2)
addEdge(edges, uk, vk, wk)
第四步、SPFA框架代码
function SPFA(n, s, edges[maxn], d[maxn], visited[maxn])q=Queue()inq ={} //实际上是个hash表,快速查找是不是在队列里SPFAInit(n, s, d, visited, q, inq) //初始化while ( not q.empty() )u = q.front()q.pop()inq.remove(u)if visited[u]++ > nreturn trueSPFARelax(u, edges, d, q, inq)return false
第五步、SPFA初始化
function SPFAInit(n, S, d[maxn], visited[maxn], q, inq)for i ->(0, n-1)d[i] = infvisited[i] = 0d[s] = 0visited[s] = 1q.push(s)inq.add(s)
第六步、实现松弛操作
function SPFARelax(u; edges[maxn], d[maxn], q, inq)for i -> (0, edges[u].size()-1)v, w = edges[u][i]if d[u] + w < d[v]d[v] = d[u] + wif not inq.has(v)q.push(v)inq.add(v)

 第一点、最短路存在
只要最短路径存在,SPFA算法必定能求出最小值。因为每次将顶点放入队尾,都是经过松弛操作达到的。即每次入队的顶点v对应的最短路径估计值d[v]都在变小。所以算法的执行会使d数组越来越小。
由于我们假定最短路一定存在,即图中没有负权圈,所以每个结点都有最短路径值。因此,算法不会无限执行下去,随着d值的逐渐变小,直到到达最短路径值时,算法结束,这时的最短路径估计值就是对应结点的最短路径值。

第二点、最短路不存在
如果存在负权圈,并且起点可以通过一些顶点到达负权圈,那么利用SPFA算法会进入一个死循环,因为d数组的值会越来越小,并且没有下限,使得最短路不存在。
那么我们假设不存在负权圈,则任何最短路上的点必定小于等于n个(没有圈),换言之,用一个数组visited[i]来记录i这个点入队的次数,所有的visited[i]必定都小于等于n,(就是上面有个广搜的时候)所以一旦有一个visited[i]>n,则表明这个图中存在负权圈。
这就是SPFA算法的其中一个终止条件。

第三点、时间复杂度
SPFA算法的最坏时间复杂度为O(nm),一般的期望时间复杂度为O(km),k为常数,m为边数(这个时间复杂度只是估计值,具体和图的结构有很大关系,而且很难证明,不过可以肯定的是至少比传统的Bellman-Ford高效很多,所以一般采用SPFA来求解带负权圈的最短路问题)。

题目

Diikstra

网络延迟时间

#define maxn 101
#define edgeType int
#define inf INT_MAX
class Solution {
public:edgeType graph[maxn][maxn];void initEdges(int n) {for (int i = 0; i < n; ++i) {for (int j = 0; j < n; ++j) {graph[i][j] = inf;}}}void addEdge(int u, int v, edgeType w) {if (graph[u][v] == inf || w < graph[u][v]) {graph[u][v] = w;}}void dijkstra(int n, int s, edgeType dist[maxn]) {bool visited[maxn];for (int i = 0; i < n; ++i) {visited[i] = false;dist[i] = inf;}dist[s] = 0;while (1) {edgeType minDist = inf;int minIndex;for (int i = 0; i < n; ++i) {if (visited[i]) {continue;}if (minDist == inf || dist[i] < minDist) {minDist = dist[i];minIndex = i;}}if (minDist == inf) {break;}visited[minIndex] = true;for (int i = 0; i < n; ++i) {if (visited[i]) {continue;}int dis = graph[minIndex][i];if (dis == inf) {continue;}if (dist[i] == inf || dist[minIndex] + dis < dist[i]) {dist[i] = dist[minIndex] + dis;}}}}int networkDelayTime(vector<vector<int>>& times, int n, int k) {initEdges(n);for (int i = 0; i < times.size(); ++i) {int u = times[i][0] - 1;int v = times[i][1] - 1;edgeType w = times[i][2];addEdge(u, v, w);}edgeType dist[maxn];dijkstra(n, k - 1, dist);int max = 0;for (int i = 0; i < n; ++i) {if (dist[i] == inf) {return -1;}if (dist[i] > max) {max = dist[i];}}return max;}
};

阈值距离内邻居最少的城市

前往目标的最小代价

Bellman-Ford

出差

字母的阶梯游戏

小怂的黄牛f

Floyed

网络延迟时间

到达目的地的方案数

Dijkstra + Heap

Dijkstra求最短路2

蓝桥王国

SPFA

路径

地铁最短路径与最少换乘

保存体力

相关文章:

图 最 短 路

Diikstra朴素 非负边权单源最短路顶点数最好小于1000少量数据结构知识和一点点的算法基础 算法描述 这个算法我们采用邻接矩阵来存储&#xff0c;有时候输入数据&#xff0c;并不是我们期待的那样&#xff0c;所以需要对数据做一些处理&#xff0c;也就是把图创建起来的过程…...

NA611系列WiFi串口服务器常见问题以及解决办法

NA611系列WiFi串口服务器是一款高性能、高可靠的工业级双频RS485 ⇌ WiFi数据双向透明传输的串口服务器。实现RS485串口数据通过WiFi实现设备联网数据交互&#xff0c;支持 IEEE 802.11 a/b/g/n 标准。WiFi串口服务器在连接、配置和使用过程中可能会遇到多种问题。以下是一些常…...

工程化与框架系列(36)--前端监控告警实践

前端监控告警实践 &#x1f514; 引言 前端监控是保障应用质量和用户体验的重要手段。本文将深入探讨前端监控的实现方案&#xff0c;包括性能监控、错误监控、用户行为监控等方面&#xff0c;以及相应的告警机制。 监控系统概述 前端监控系统主要包括以下方面&#xff1a;…...

【深度学习|目标检测】YOLO系列anchor-based原理详解

YOLO之anchor-based 一、关于anchors的设置二、网络如何利用anchor来训练关于register_buffer训练阶段的anchor使用推理阶段的anchor使用 三、训练时的正负样本匹配anchor匹配grid匹配 总结起来其实就是&#xff1a;基于anchor-based的yolo就是基于三个检测头的分支上的grids和…...

vue3+Ts+elementPlus二次封装Table分页表格,表格内展示图片、switch开关、支持

目录 一.项目文件结构 二.实现代码 1.子组件&#xff08;表格组件&#xff09; 2.父组件&#xff08;使用表格&#xff09; 一.项目文件结构 1.表格组件&#xff08;子组件&#xff09;位置 2.使用表格组件的页面文件&#xff08;父组件&#xff09;位置 3.演示图片位置 ele…...

【C/C++】文件句柄

什么是文件句柄&#xff1f; 文件句柄&#xff08;File Handle&#xff09;是操作系统中的一种抽象概念&#xff0c;它用来表示一个打开的文件或输入/输出设备。 文件句柄是程序与文件之间的桥梁&#xff0c;程序通过文件句柄来访问和操作文件的内容。 1. 文件句柄——作用 文…...

Matlab 基于专家pid控制的时滞系统

1、内容简介 Matlab 185-基于专家pid控制的时滞系统 可以交流、咨询、答疑 2、内容说明 略 在处理时滞系统&#xff08;Time Delay Systems&#xff09;时&#xff0c;使用传统的PID控制可能会面临挑战&#xff0c;因为时滞会导致系统的不稳定或性能下降。专家PID控制通过结…...

【高项】信息系统项目管理师(六)项目进度管理【3分】

项目进度管理是为了保证项目按时完成。对项目所需的各个过程进行管理,包括规划进度、定义活动、排列活动顺序、估算活动持续时间、制订项目进度计划和控制进度。小型项目中,定义活动、排列活动顺序、估算活动持续时间以及制订进度模型形成进度计划等过程的联系非常紧密,可以…...

通过MATLAB和Carsim进行联合仿真,利用强化学习实现自动驾驶人机控制权策略的详细步骤和示例代码

以下是一个通过MATLAB和Carsim进行联合仿真,利用强化学习实现自动驾驶人机控制权策略的详细步骤和示例代码: 步骤概述 Carsim配置:对Carsim进行必要的设置,包括车辆模型、道路场景等,并生成S - function接口。MATLAB环境搭建:在MATLAB中配置Carsim的S - function,并创建…...

iOS 模块化架构设计:主流方案与实现详解

随着 iOS 工程规模的扩大&#xff0c;模块化设计成为提升代码可维护性、团队协作效率和开发灵活性的关键。本文将探讨为什么需要模块化&#xff0c;介绍四种主流的模块化架构方案&#xff08;协议抽象、依赖注入、路由机制和事件总线&#xff09;&#xff0c;并通过代码示例和对…...

PostreSQL指南-内幕探索-学习笔记-01-数据库集簇的逻辑与物理结构

目录 一、环境信息 二、参考内容 三、逻辑结构概念 四、物理结构概念 五、逻辑映射关系 1、数据库与oid映射关系 2、堆表对象与oid映射关系 五、物理映射关系 1、数据库与oid映射关系 2、堆表对象与oid映射关系 六、数据库文件布局 1、表格 2、postmaster.pid文件解…...

java使用(Preference、Properties、XML、JSON)实现处理(读写)配置信息或者用户首选项的方式的代码示例和表格对比

在Java应用程序中&#xff0c;处理应用首选项&#xff08;preferences&#xff09;有多种方法&#xff0c;包括使用java.util.prefs.Preferences类、属性文件&#xff08;如.properties文件&#xff09;、XML文件和JSON文件。下面是每种方法的详细说明和代码示例&#xff0c;最…...

spring动态代理是在生命周期的哪个阶段实现的

Spring AOP&#xff08;面向切面编程&#xff09;的动态代理是在 Bean 生命周期的 初始化后阶段 实现的&#xff0c;具体来说是在 BeanPostProcessor 的 postProcessAfterInitialization() 方法中完成的。下面我们来详细分析 Spring AOP 动态代理的实现位置及其工作原理。 1. S…...

Oracle静默安装方法

Web服务器上面的Linux一般是不会有图形界面的&#xff0c;所有通过图形界面来安装Linux的方式在没有图形界面的Linux上面是行不通的&#xff0c;我们要使用的安装方式叫做Linux的静默安装。即在没有图形界面的Linux上面安装。 1. 下载地址 http://www.oracle.com/technetwork…...

本地部署deepseek-r1建立向量知识库和知识库检索实践【代码】

目录 一、本地部署DS 二、建立本地知识库 1.安装python和必要的库 2.设置主目录工作区 3.编写文档解析脚本 4.构建向量数据库 三、基于DS,使用本地知识库检索 本地部署DS,其实非常简单,我写了一篇操作记录,我终于本地部署了DeepSeek-R1(图文全过程)-CSDN博客 安装…...

单词翻转(信息学奥赛一本通-1144)

【题目描述】 输入一个句子(一行)&#xff0c;将句子中的每一个单词翻转后输出。 【输入】 只有一行&#xff0c;为一个字符串&#xff0c;不超过500个字符。单词之间以空格隔开。 【输出】 翻转每一个单词后的字符串&#xff0c;单词之间的空格需与原文一致。 【输入样例】 he…...

Python基础入门掌握(十三)

从基础到进阶&#xff0c;轻松掌握文件读写 目录 文件操作的基本概念 文件的打开与关闭 读取文件内容 写入文件内容 文件操作的高级技巧 总结与建议‍ 文件操作的基本概念 在Python中&#xff0c;文件操作主要涉及以下几个步骤&#xff1a; 打开文件&#xff08;open…...

【再读】R1-Onevision通过跨模态形式化为复杂多模态推理任务提供了系统性解决方案

R1-Onevision:跨模态形式化驱动的多模态推理技术突破,R1-Onevision通过跨模态形式化、双阶段训练和教育级基准测试,为多模态推理树立了新标杆。其技术创新不仅提升了模型在复杂任务中的表现,更重要的是为行业提供了一种可解释、可迁移的多模态处理范式。随着形式化方法的不断…...

【AWS入门】2025 AWS亚马逊云科技账户注册指南

【AWS入门】2025 AWS亚马逊云科技账户注册指南 A Guide To Register a New account on AWS By JacksonML 0. AWS亚马逊云科技简介 Amazon Web Service(AWS) 即亚马逊云科技&#xff0c;其在全球Cloud Computing(云计算)市场占有最为重要的地位。 AWS连续13年被Gartner评为…...

重生之我在学Vue--第18天 Vue 3 项目功能扩展

重生之我在学Vue–第18天 Vue 3 项目功能扩展 文章目录 重生之我在学Vue--第18天 Vue 3 项目功能扩展前言一、权限管理系统1.1 用户角色体系设计1.2 路由权限控制1.3 组件级权限控制 二、分页与搜索系统2.1 分页类型对比2.2 分页组件实现2.3 搜索功能实现 三、文件上传系统3.1 …...

基于SpringBoot的房地产销售管理系统【附源码】

基于SpringBoot的房地产销售管理系统&#xff08;源码L文说明文档&#xff09; 目录 4 系统设计 4.1用户登录功能的详细实现 4.2管理员权限的功能实现 4.2.1客户信息管理功能的详细实现 4.2.2房产管理功能的详细实现 4.2.3预约看房功能的详细实现 4.2.4论…...

数组题型-二分查找-JS

二分查找伪代码 1.定义 target 是在⼀个在左闭右闭的区间⾥&#xff0c;也就是[left, right] let left0;let rightnums.length-1;// 定义target在左闭右闭的区间⾥&#xff0c;[left, right]while(left<right){// 当leftright&#xff0c;区间[left, right]依然有效&#x…...

STL——vector

目录 1 vector介绍 2 vector使用 2.1 vector的定义 2.1.1 无参构造 2.1.2 构造并初始化N个Val 2.1.3 拷贝构造 2.1.4 使用迭代器初始化构造 2.1.5 使用大括号初始化构造 2.2 vector的迭代器 2.2.1 const 迭代器 2.3 vector的空间增长 2.4 vector的增删改查 2.5 ve…...

国内首款载重1吨级无人运输机TP1000首飞成功 2026年投入应急救援

大湾区经济网珠海快讯&#xff0c;据央视新闻报道&#xff0c;3月15日上午&#xff0c;国内首款载重1吨级大型无人运输机TP1000在山东成功首飞。该机由中国民航适航标准完全自主研发&#xff0c;起飞重量3.3吨&#xff0c;满载航程达1000公里&#xff0c;具备智能空投功能&…...

python-leetcode 54.全排列

题目&#xff1a; 给定不含重复数字的数组nums,返回其所有可能的全排列&#xff0c;可以按任意顺序返回答案 回溯法 一种通过探索所有可能的候选解来找出所有的解的算法。如果候选解被确认不是一个解&#xff08;或者至少不是最后一个解&#xff09;&#xff0c;回溯算法会通…...

人工智能实现电脑任务自动化的开源软件

人工智能实现电脑任务自动化的开源软件 hallo大家好&#xff0c;我是星哥&#xff0c;今天给大家介绍一个开源软件&#xff0c;融合了人工智能与机器人流程自动化&#xff08;AIRPA&#xff09;的开源软件autoMate! autoMate是什么 autoMate 是一款由开源开发的本地自动化工…...

串口烧录出现频繁回复乱码 频繁回复一个数字且烧录失败 字节混乱

这是因为你的芯片没有处于系统存储区启动一直未进入bootloader 解决办法是检查boot引脚接正确没&#xff0c;要在系统存储器启动...

ens33没有分配到IPV4问题

方法一&#xff1a;手动为 ens33 接口分配 IP 地址 你能够借助 ip 命令手动给 ens33 接口分配 IP 地址。不过这种方式在系统重启之后就会失效。 步骤 查看网络信息 先查看一下当前网络的子网信息&#xff0c;例如网关地址和子网掩码等&#xff0c;你可以通过路由器管理界面或…...

搭建主从服务器

任务需求 客户端通过访问 www.nihao.com 后&#xff0c;能够通过 dns 域名解析&#xff0c;访问到 nginx 服务中由 nfs 共享的首页文件&#xff0c;内容为&#xff1a;Very good, you have successfully set up the system. 各个主机能够实现时间同步&#xff0c;并且都开启防…...

【实测闭坑】LazyGraphRAG利用本地ollama提供Embedding model服务和火山引擎的deepseek API构建本地知识库

LazyGraphRAG 2024年4月&#xff0c;为解决传统RAG在全局性的查询总结任务上表现不佳&#xff0c;微软多部门联合提出Project GraphRAG&#xff08;大模型驱动的KG&#xff09;&#xff1b;2024年7月&#xff0c;微软正式开源GraphRAG项目&#xff0c;引起极大关注&#xff0c…...

[Lc14_priority_queue] 最后一块石头重量 | 数据流中的第 K 大元素 | 前K个高频单词 | 数据流的中位数

目录 1.最后一块石头的重量 题解 2.数据流中的第 K 大元素 题解 3.前K个高频单词 题解 代码 ⭕4.数据流的中位数 题解 在C中&#xff0c;使用标准库中的priority_queue&#xff0c;默认情况下它是一个最大堆&#xff08;即大堆排序&#xff09;&#xff0c;这意味着最…...

Electron使用WebAssembly实现CRC-16 MAXIM校验

Electron使用WebAssembly实现CRC-16 MAXIM校验 将C/C语言代码&#xff0c;经由WebAssembly编译为库函数&#xff0c;可以在JS语言环境进行调用。这里介绍在Electron工具环境使用WebAssembly调用CRC-16 MAXIM格式校验的方式。 CRC-16 MAXIM校验函数WebAssembly源文件 C语言实…...

案例5_1:单位数码管显示0

文章目录 文章介绍效果图仿真图5_1放置单位数码管 代码5_1.c 文章介绍 效果图 仿真图5_1 复制案例1_2的仿真图&#xff0c;在此基础上修改 注意&#xff1a;栅格大小需要缩小 放置单位数码管 代码5_1.c #include <reg52.h>#define uchar unsigned char #define uint un…...

OpenCV计算摄影学(20)非真实感渲染之增强图像的细节函数detailEnhance()

操作系统&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 编程语言&#xff1a;C11 算法描述 此滤波器增强特定图像的细节。 cv::detailEnhance用于增强图像的细节&#xff0c;通过结合空间域和频率域的处理&#xff0c;提升图像中特定细节…...

linux按照nginx

第一步先按照依赖gcc 一键安装上面四个依赖 Nginx的编译安装需要一些依赖库&#xff0c;如gcc、make、zlib、openssl等。可以使用yum命令安装这些依赖&#xff1a; yum -y install gcc zlib zlib-devel pcre-devel openssl openssl-devel 创建目录 mkdir /usr/nginx 切换…...

SpringMVC(八)Knife4j 接口文档

目录 一 基础使用 1 配置pom.xml相关依赖 2 项目配置 3 输入指定路径&#xff08;http://localhost:8080/doc.html&#xff09; 二 一些使用方法 1 Tag 2 Operation 3 Schema 4 Parameter 5 可以根据需求来设置 补充&#xff1a;日期的格式化 Knife4j 是基于 Swag…...

Java集成MQTT和Kafka实现稳定、可靠、高性能的物联网消息处理系统

Java集成MQTT和Kafka实现高可用方案 1. 概述 在物联网(IoT)和分布式系统中,消息传递的可靠性和高可用性至关重要。本文将详细介绍如何使用Java集成MQTT和Kafka来构建一个高可用的消息处理系统。 MQTT(消息队列遥测传输)是一种轻量级的发布/订阅协议,适用于资源受限的设备和…...

【操作系统安全】任务6:Linux 系统文件与文件系统安全 学习指南

目录 一、文件系统基础概念 二、查看文件系统信息 2.1 磁盘空间查看 2.2 分区与挂载管理 2.3 文件系统类型操作 三、文件系统权限配置 3.1 基础权限管理 3.2 所有权管理 3.3 特殊权限设置 四、文件操作基础 4.1 文件创建 4.2 文件删除 4.3 文件复制与移动 4.4 文件…...

华为中小型企业项目案例

实验目的(1) 熟悉华为交换机和路由器的应用场景 (2) 掌握华为交换机和路由器的配置方法 实验拓扑实验拓扑如图所示。 华为中小型企业项目案例拓扑图 实验配置市场部和技术部的配置创建VLANLSW1的配置 [LSW1]vlan batch 10 20 [LSW1]q…...

Zabbix安装(保姆级教程)

Zabbix 是一款开源的企业级监控解决方案,能够监控网络的多个参数以及服务器、虚拟机、应用程序、服务、数据库、网站和云的健康状况和完整性。它提供了灵活的通知机制,允许用户为几乎任何事件配置基于电子邮件的告警,从而能够快速响应服务器问题。Zabbix 基于存储的数据提供…...

JDBC数据库连接池技术详解——从传统连接方式到高效连接管理

1. 引言 在开发数据库应用时&#xff0c;我们通常需要与数据库建立连接并执行SQL语句。传统的JDBC连接方式虽然简单直接&#xff0c;但在高并发场景下容易带来性能问题&#xff0c;甚至导致系统崩溃。因此&#xff0c;引入数据库连接池&#xff08;Connection Pool&#xff09…...

微服务存在的问题及解决方案

微服务存在的问题及解决方案 1. 存在问题 1.1 接口拖慢 因为一个接口在并发时&#xff0c;正好执行时长又比较长&#xff0c;那么当前这个接口占用过多的 Tomcat 连接&#xff0c;导致其他接口无法即时获取到 Tomcat 连接来完成请求&#xff0c;导致接口拖慢&#xff0c;甚至…...

C语言中的结构体数组

一、什么是结构体数组? 在C语言中,**结构体(struct)**是一种自定义数据类型,它可以将不同类型的数据组合成一个单一的数据结构。结构体数组则是多个结构体元素按顺序存储在内存中的集合。通过结构体数组,可以存储多个相同类型的结构体,每个结构体都拥有自己独立的成员变…...

[GESP 202412 一级 T1] 温度转换

描述 小杨最近学习了开尔文温度、摄氏温度和华氏温度的转换。令符号 KK 表示开尔文温度&#xff0c;符号 CC 表示摄氏温度&#xff0c;符号 FF 表示华氏温度&#xff0c;这三者的转换公式如下&#xff1a; C K - 273.15 F C*1.8 32 现在小杨想编写一个程序计算某一开尔文…...

虚幻基础:GAS

文章目录 Gameplay Tag&#xff1a;项目类&#xff1a;可直接按标签管理游戏中的各种对象。其他&#xff1a;数据表格&#xff1a;gameplaytag primary data asset&#xff1a;项目类&#xff1a;存储游戏中的数据&#xff1a;通常用于配置表蓝图&#xff1a;primary data asse…...

案例:图书管理

掌握图书管理案例的实现&#xff0c;能够使用Spring Boot整合Thymeleaf完成图书管理案例。 1.任务需求 &#xff08;1&#xff09;项目使用Spring Boot整合Thymeleaf&#xff0c;项目展示的页面效果全部通过Thymeleaf的模板文件实现。 &#xff08;2&#xff09;查询所有图书。…...

Pycharm 社区版安装教程

找到安装包双击安装文件---点击下一步 一般路径是&#xff1a;C:\Rambo\Software\Development 选择完成后就是如下地址&#xff1a; C:\Rambo\Software\Development\PyCharm Community Edition 2024.3.3 点击上述3个位置就可以了----下一步 等待安装就可以了---完成后点击完成…...

RabbitMQ 全面详解(附面试重点)

RabbitMQ 全面详解&#xff08;附面试重点&#xff09; 一、RabbitMQ 与其他消息队列对比 特性RabbitMQKafkaRocketMQActiveMQ设计定位企业级消息中间件&#xff08;传统业务场景&#xff09;高吞吐分布式流处理平台&#xff08;日志、大数据&#xff09;金融级高可靠消息中间…...

浏览器好用的去广告插件和暗黑模式护眼插件

提升浏览体验&#xff1a;Edge浏览器的Adblock和Dark Mode扩展 Adblock&#xff1a;告别广告干扰 功能&#xff1a;高效拦截弹窗、横幅和视频广告&#xff0c;提升网页整洁度&#xff0c;加快加载速度&#xff0c;节省流量。安装链接&#xff1a;安装Adblock Dark Mode for E…...

VBA第二十七期 数据录入中验证格式有效性

Excel的数据有效性验证是一个有用的工具&#xff0c;但会需要我们向使用数据单元格提前设定有效性验证规则。这样一来使数据的有效性验证功能不能使用在VBA编程中。下面介绍如何在工作表中使用Change事件来创建数据有效性验证过程。监视单元格区域验证数据输入的有效性&#xf…...