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

【8】分块学习笔记

前言

分块是一种重要的高级数据结构思想,核心为大段维护,局部朴素

顺带一提,由于个人技术水平,本篇博客的难度并没有标题所述的 8 8 8 级。分块还是很难的。

分块

分块,是“优雅的暴力”。

分块的基本思想是把数据分为若干个块(一般块长为 n \sqrt{n} n ),一个块内的数据在操作中具有相同的属性,对于整块,可以直接设置一个变量表示变化。由于块数为 n \sqrt{n} n ,整块更新的复杂度最多为 n \sqrt{n} n 。对于非整块,可以朴素更新。由于一个块的块长为 n \sqrt{n} n ,朴素更新的复杂度最多为 n \sqrt{n} n 。综上,省略常数,一次操作的时间复杂度就被降低为了 n \sqrt{n} n 。所以分块的时间复杂度大约为 O ( n n ) O(n\sqrt{n}) O(nn ) ,属于根号数据结构。

具体实现方式见下面的代码。(例题 1 1 1 2 2 2 是两种不同的实现方式)

分块例题

例题 1 1 1

P2357 守墓人

对于操作 1 1 1 4 4 4 ,是分块的经典模板。

设块号为 i i i 的块表示范围为 [ ( i − 1 ) × n + 1 , i × n ] [(i-1)\times\sqrt{n}+1,i\times\sqrt{n}] [(i1)×n +1,i×n ]

首先预处理出每个位置处于的块,记作 p o s [ i ] pos[i] pos[i] ,然后输入 l , r l,r l,r 后,令 p = p o s [ l ] , q = p o s [ r ] p=pos[l],q=pos[r] p=pos[l],q=pos[r] 。同时记录两个数组: a d d [ i ] add[i] add[i] ,表示第 i i i 块的增量标记。 s u m [ i ] sum[i] sum[i] ,表示第 i i i 块的整块和。

对于 l ≤ i ≤ p ∗ n l\le i\le p*\sqrt{n} lipn ,是前面不完整的一段,朴素更新。

对于 ( q − 1 ) ∗ n + 1 ≤ i ≤ r (q-1)*\sqrt{n}+1\le i\le r (q1)n +1ir ,是后面不完整的一段,朴素更新。

对于 p + 1 ≤ j ≤ q − 1 p+1\le j\le q-1 p+1jq1 j j j 为块号),是整块完整更新的块,更新标记 a d d [ j ] + = k add[j]+=k add[j]+=k

查询的时候,不完整的两段朴素更新,中间的整块直接查询整块和。注意都要加上增量标记。

对于其他操作,可以直接单点修改,记得更新增量标记。

#include <bits/stdc++.h>
using namespace std;
long long n,f,a[2000001],op,l,r,k,lb[2000001],rb[2000001],sum[2000001],pos[2000001],add[2000001];
inline long long read()
{long long x=0,f=1;char ch=getchar();while (ch<'0'||ch>'9'){if (ch=='-') f=-1;ch=getchar();}while (ch>='0'&&ch<='9'){x=x*10+ch-48;ch=getchar();}return x*f;
}void adde()
{l=read();r=read();k=read();int p=pos[l],q=pos[r];if(p==q)for(int i=l;i<=r;i++)a[i]+=k,sum[p]+=k;else{for(int i=l;i<=rb[p];i++)a[i]+=k,sum[p]+=k;for(int i=lb[q];i<=r;i++)a[i]+=k,sum[q]+=k;for(int i=p+1;i<=q-1;i++)add[i]+=k;}
}void ask()
{long long ans=0;l=read();r=read();int p=pos[l],q=pos[r];if(p==q){for(int i=l;i<=r;i++)ans+=a[i];printf("%lld\n",ans+(r-l+1)*add[p]);}else{for(int i=l;i<=rb[p];i++)ans+=a[i];ans+=(rb[p]-l+1)*add[p];for(int i=lb[q];i<=r;i++)ans+=a[i];ans+=(r-lb[q]+1)*add[q];for(int i=p+1;i<=q-1;i++)ans+=sum[i],ans+=add[i]*(rb[i]-lb[i]+1); printf("%lld\n",ans);}
}int main()
{n=read();f=read();int kl=sqrt(n);for(int i=1;i<=kl;i++){lb[i]=(i-1)*kl+1;rb[i]=i*kl;}if(rb[kl]<n)kl++,lb[kl]=rb[kl-1]+1,rb[kl]=n;for(int i=1;i<=n;i++)a[i]=read();for(int i=1;i<=kl;i++)for(int j=lb[i];j<=rb[i];j++){pos[j]=i;sum[i]+=a[j];}for(int i=0;i<f;i++){op=read();if(op==1)adde();	else if(op==2){k=read();a[1]+=k,sum[1]+=k;;}else if(op==3){k=read();a[1]-=k,sum[1]-=k;}else if(op==4)ask();else if(op==5)printf("%lld\n",a[1]+add[1]);}return 0;
}

例题 2 2 2

问题 B: 分块2(站外题,提供题面展示)



设块号为 i i i 的块表示范围为 [ ( i − 1 ) × n + 1 , i × n ] [(i-1)\times\sqrt{n}+1,i\times\sqrt{n}] [(i1)×n +1,i×n ]

首先预处理出每个位置处于的块,记作 i d [ i ] id[i] id[i] 。预处理时记录每一块的元素数量,同时记录每一块的每个元素的值与在原数组中的位置,用于块内排序。同时记录两个数组: a d d [ i ] add[i] add[i] ,表示第 i i i 块的增量标记。 d [ i ] d[i] d[i] ,表示原数组中第 i i i 项对应块内编号为 d [ i ] d[i] d[i]

修改操作

对于 l ≤ i ≤ p ∗ n l\le i\le p*\sqrt{n} lipn ,是前面不完整的一段,朴素更新,更新之后依据每块位置 d [ i ] d[i] d[i] 的信息更新块内信息。然后重新块内排序,更新 d d d 数组。

对于 ( q − 1 ) ∗ n + 1 ≤ i ≤ r (q-1)*\sqrt{n}+1\le i\le r (q1)n +1ir ,是后面不完整的一段,朴素更新,更新之后依据每块位置 d [ i ] d[i] d[i] 的信息更新块内信息。然后重新块内排序,更新 d d d 数组。

对于 p + 1 ≤ j ≤ q − 1 p+1\le j\le q-1 p+1jq1 j j j 为块号),是整块完整更新的块,更新标记 a d d [ j ] + = k add[j]+=k add[j]+=k 。由于块内元素同增同减,顺序不变,不需要块内重排或更新 d d d 数组

时间复杂度: O ( n log ⁡ n + n log ⁡ n + n ) O(\sqrt{n}\log\sqrt{n}+\sqrt{n}\log\sqrt{n}+\sqrt{n}) O(n logn +n logn +n )

询问操作

对于 l ≤ i ≤ p ∗ n l\le i\le p*\sqrt{n} lipn ,是前面不完整的一段,朴素查询,比较每个元素加上其对应的组的 a d d add add 值与 c 2 c^2 c2 的大小,如果小于, a n s ans ans 自增。

对于 ( q − 1 ) ∗ n + 1 ≤ i ≤ r (q-1)*\sqrt{n}+1\le i\le r (q1)n +1ir ,是后面不完整的一段,朴素查询,比较每个元素加上其对应的组的 a d d add add 值与 c 2 c^2 c2 的大小,如果小于, a n s ans ans 自增。

对于 p + 1 ≤ j ≤ q − 1 p+1\le j\le q-1 p+1jq1 j j j 为块号),是整块完整更新的块,由于块内元素有序,可以在每一块内部二分查找最大的小于 c 2 c^2 c2 减去对应 a d d add add 值的元素,得到编号后就可以计算出小于 c 2 c^2 c2 的元素个数。

时间复杂度: O ( n + n + n log ⁡ n ) O(\sqrt{n}+\sqrt{n}+\sqrt{n}\log\sqrt{n}) O(n +n +n logn )

总的复杂度为(忽略低次项和常数): O ( n n log ⁡ n ) O(n\sqrt{n}\log\sqrt{n}) O(nn logn )

#include <bits/stdc++.h>
using namespace std;
struct node
{int val,p;
}nei[250][250];
long long n,k,op,l,r,c,a[50010],id[50010],add[50010],num[50010],d[50010];
bool cmp(struct node a,struct node b)
{return a.val<b.val;
}void adde()
{long long p=id[l],q=id[r];if(p==q){for(long long i=l;i<=r;i++){a[i]+=c;nei[p][d[i]].val+=c;}sort(nei[p]+1,nei[p]+num[p]+1,cmp);for(int j=1;j<=num[p];j++)d[nei[p][j].p]=j;}else{for(long long i=p+1;i<=q-1;i++)add[i]+=c;for(long long i=l;i<=p*k;i++){a[i]+=c;nei[p][d[i]].val+=c;}sort(nei[p]+1,nei[p]+num[p]+1,cmp);for(int j=1;j<=num[p];j++)d[nei[p][j].p]=j;for(long long i=(q-1)*k+1;i<=r;i++){a[i]+=c;nei[q][d[i]].val+=c;}sort(nei[q]+1,nei[q]+num[q]+1,cmp);for(int j=1;j<=num[q];j++)d[nei[q][j].p]=j;}
}long long search(long long z,long long key)
{long long l=0,r=num[z];while(l<r){long long mid=(l+r+1)/2;if(nei[z][mid].val<key)l=mid;else r=mid-1;}return l;
}long long ask()
{long long p=id[l],q=id[r],ans=0;if(p==q){for(long long i=l;i<=r;i++)if(a[i]+add[p]<c*c)ans++;return ans;}else{for(long long i=p+1;i<=q-1;i++)ans+=search(i,c*c-add[i]);for(long long i=l;i<=p*k;i++)if(a[i]+add[p]<c*c)ans++;for(long long i=(q-1)*k+1;i<=r;i++)if(a[i]+add[q]<c*c)ans++;return ans;}
}int main()
{scanf("%lld",&n);k=sqrt(n);for(long long i=1;i<=n;i++){scanf("%lld",&a[i]);id[i]=(i-1)/k+1;num[id[i]]++;nei[id[i]][i-(id[i]-1)*k].val=a[i];nei[id[i]][i-(id[i]-1)*k].p=i;}for(long long i=1;i<=id[n];i++){sort(nei[i]+1,nei[i]+num[i]+1,cmp);for(int j=1;j<=num[i];j++)d[nei[i][j].p]=j;}for(long long i=1;i<=n;i++){scanf("%lld%lld%lld%lld",&op,&l,&r,&c);if(op==0)adde();else if(op==1)printf("%lld\n",ask());} return 0;
}

例题 3 3 3

问题 C: 分块3(站外题,提供题面展示)



修改操作同例题 2 2 2

询问操作

对于 l ≤ i ≤ p ∗ n l\le i\le p*\sqrt{n} lipn ,是前面不完整的一段,朴素查询,比较每个元素加上其对应的组的 a d d add add 值与 c c c 的大小,如果小于,比较查询结果加上对应 a d d add add 值与 a n s ans ans 的大小,如果大于,更新 a n s ans ans 的值。

对于 ( q − 1 ) ∗ n + 1 ≤ i ≤ r (q-1)*\sqrt{n}+1\le i\le r (q1)n +1ir ,是后面不完整的一段,朴素查询,比较每个元素加上其对应的组的 a d d add add 值与 c c c 的大小,如果小于,比较查询结果加上对应 a d d add add 值与 a n s ans ans 的大小,如果大于,更新 a n s ans ans 的值。

对于 p + 1 ≤ j ≤ q − 1 p+1\le j\le q-1 p+1jq1 j j j 为块号),是整块完整更新的块,由于块内元素有序,可以在每一块内部二分查找最大的小于 c c c 减去对应 a d d add add 值的元素,得到结果后就可以计算出小于 c c c 的元素的最大值,然后和 a n s ans ans max ⁡ \max max 即可。

注意:如果查询结果为不存在,应当返回负无穷,否则会WA掉。

时间复杂度: O ( n + n + n log ⁡ n ) O(\sqrt{n}+\sqrt{n}+\sqrt{n}\log\sqrt{n}) O(n +n +n logn )

总的复杂度为(忽略低次项和常数): O ( n n log ⁡ n ) O(n\sqrt{n}\log\sqrt{n}) O(nn logn )

#include <bits/stdc++.h>
using namespace std;
struct node
{int val,p;
}nei[500][500];
long long n,k,op,l,r,c,a[100010],id[100010],add[100010],num[100010],d[100010];
bool cmp(struct node a,struct node b)
{return a.val<b.val;
}void adde()
{long long p=id[l],q=id[r];if(p==q){for(long long i=l;i<=r;i++){a[i]+=c;nei[p][d[i]].val+=c;}sort(nei[p]+1,nei[p]+num[p]+1,cmp);for(int j=1;j<=num[p];j++)d[nei[p][j].p]=j;}else{for(long long i=p+1;i<=q-1;i++)add[i]+=c;for(long long i=l;i<=p*k;i++){a[i]+=c;nei[p][d[i]].val+=c;}sort(nei[p]+1,nei[p]+num[p]+1,cmp);for(int j=1;j<=num[p];j++)d[nei[p][j].p]=j;for(long long i=(q-1)*k+1;i<=r;i++){a[i]+=c;nei[q][d[i]].val+=c;}sort(nei[q]+1,nei[q]+num[q]+1,cmp);for(int j=1;j<=num[q];j++)d[nei[q][j].p]=j;}
}long long search(long long z,long long key)
{long long l=0,r=num[z];while(l<r){long long mid=(l+r+1)/2;if(nei[z][mid].val<key)l=mid;else r=mid-1;}if(l==0)return -99999999;else return nei[z][l].val;
}long long ask()
{long long p=id[l],q=id[r],ans=-1;if(p==q){for(long long i=l;i<=r;i++)if(a[i]+add[p]<c)ans=max(ans,a[i]+add[p]);return ans;}else{for(long long i=p+1;i<=q-1;i++)ans=max(search(i,c-add[i])+add[i],ans);for(long long i=l;i<=p*k;i++)if(a[i]+add[p]<c)ans=max(ans,a[i]+add[p]);for(long long i=(q-1)*k+1;i<=r;i++)if(a[i]+add[q]<c)ans=max(ans,a[i]+add[q]);return ans;}
}int main()
{scanf("%lld",&n);k=sqrt(n);for(long long i=1;i<=n;i++){scanf("%lld",&a[i]);id[i]=(i-1)/k+1;num[id[i]]++;nei[id[i]][i-(id[i]-1)*k].val=a[i];nei[id[i]][i-(id[i]-1)*k].p=i;}for(long long i=1;i<=id[n];i++){sort(nei[i]+1,nei[i]+num[i]+1,cmp);for(int j=1;j<=num[i];j++)d[nei[i][j].p]=j;}for(long long i=1;i<=n;i++){scanf("%lld%lld%lld%lld",&op,&l,&r,&c);if(op==0)adde();else if(op==1)printf("%lld\n",ask());} return 0;
}

例题 4 4 4

P10590 磁力块

有一个很显然的 BFS,对于每一个吸到的新磁力块,遍历序列,把所有它能吸到的磁力块加入一个队列进行扩展。这样时间复杂度是 O ( n 2 ) O(n^2) O(n2),不能通过。

考虑影响是否能吸到的两个因素,一个是利用 x , y x,y x,y 计算出的距离,另一个是质量 m m m。对于这种问题,经典的做法是排序维护第一个变量,数据结构维护第二个变量。

由于本题需要取出可以吸到的磁力块入队,故 log ⁡ \log log 数据结构在本题中不好用。我们考虑分块。把所有磁力块按照距离升序排序,每 n \sqrt{n} n 个元素分成一块。块内按照 m m m 升序排序,并记录距离的最大值。

当我们扩展一个磁力块时,从小到大遍历序列中的每一块。

对于一个最大距离小于等于吸引半径的块,所有磁力块均处于吸引半径之内。可以对于每一块记录一个 l a la la,表示块中已经前 l a − 1 la-1 la1 个磁力块已经被吸引。我们只需要利用 l a la la,遍历到第 x x x 个元素,使这个元素的 m m m 大于当前吸力即可。由于 m m m 升序排序,所以这一块中所有可以被吸走的磁力块要么在之前被吸走,要么在这一次被吸走,满足条件。之后,令 l a = x la=x la=x

对于第一个最大距离大于吸引半径的块,根据遍历顺序以及距离升序排序,之后的块中所有元素距离必然大于吸引半径,可以处理完这一块之后退出循环。这一块之中有的磁力块可以被吸走,有的磁力块不可以被吸走。我们暴力求出每一个能够吸走的磁力块,标记已经被吸走,之后排序重构。均衡复杂度之后为 O ( n n log ⁡ n ) O(n\sqrt{n\log n}) O(nnlogn ),可以通过。

事实上,可以继续优化。在处理第一个最大距离大于吸引半径的块时,我们不进行排序重构。改为在处理最大距离小于等于吸引半径的块时,如果遇到一个被吸走的磁力块,直接跳过到下一个。由于 m m m 升序排序,依旧满足要求。时间复杂度 O ( n n ) O(n\sqrt{n}) O(nn )

#include <bits/stdc++.h>
using namespace std;
struct val
{long long m,p,r;double d;
}a[300000];
long long xq,yq,x,y,p,r,n,k,qp[300000],qr[300000],h=1,t=0,id[300000],la[300000],lc[300000],rc[300000],ans=-1;
double mx[300000];
bool cmp1(struct val a,struct val b)
{return a.d<b.d;
}bool cmp2(struct val a,struct val b)
{return a.m<b.m;
}double dist(long long x1,long long y1,long long x2,long long y2)
{return sqrt((x1-x2)*(x1-x2)+(y1-y2)*(y1-y2));
}void expand(long long p,long long r)
{for(int i=1;i<=(n+k-1)/k;i++)if(mx[i]<=r)while(a[la[i]].m<=p&&la[i]<=rc[i]){if(a[la[i]].m!=-1e10)qp[++t]=a[la[i]].p,qr[t]=a[la[i]].r,a[la[i]].m=-1e10;la[i]++;}else{la[i]=lc[i];for(int j=lc[i];j<=rc[i];j++)if(a[j].m!=-1e10&&a[j].m<=p&&a[j].d<=r)qp[++t]=a[j].p,qr[t]=a[j].r,a[j].m=-1e10;break;}
}int main()
{scanf("%lld%lld%lld%lld%lld",&xq,&yq,&p,&r,&n);qp[++t]=p,qr[t]=r,k=sqrt(n);for(int i=1;i<=n;i++){scanf("%lld%lld%lld%lld%lld",&x,&y,&a[i].m,&a[i].p,&a[i].r);a[i].d=dist(xq,yq,x,y);}sort(a+1,a+n+1,cmp1);for(int i=1;i<=(n+k-1)/k;i++)lc[i]=1e10;for(long long i=1;i<=n;i++)id[i]=(i-1)/k+1,lc[id[i]]=min(lc[id[i]],i),rc[id[i]]=max(rc[id[i]],i),mx[id[i]]=max(mx[id[i]],a[i].d);for(int i=1;i<=(n+k-1)/k;i++)la[i]=lc[i],sort(a+lc[i],a+rc[i]+1,cmp2);while(h<=t)ans++,expand(qp[h],qr[h]),h++;printf("%lld\n",ans);return 0;
}

后记

我发现自己其实有学习数据结构的天赋,别人平均 2000 m s 2000ms 2000ms 的题目我通过优化做到了 729 m s 729ms 729ms ,还是很有成就感的。

2022/3/31 省选前夜 22:33

相关文章:

【8】分块学习笔记

前言 分块是一种重要的高级数据结构思想&#xff0c;核心为大段维护&#xff0c;局部朴素。 顺带一提&#xff0c;由于个人技术水平,本篇博客的难度并没有标题所述的 8 8 8 级。分块还是很难的。 分块 分块&#xff0c;是“优雅的暴力”。 分块的基本思想是把数据分为若干…...

Deployment声明式更新与应用式更新对比

目录 1. 声明式更新 特点 相关命令 示例 2. 命令式更新 特点 相关命令 示例 3. 声明式更新 vs 命令式更新 4. 声明式更新的优势 5. 命令式更新的适用场景 6. 总结 在 Kubernetes 中&#xff0c;声明式更新和命令式更新是两种不同的资源管理方式。它们分别通过不同的…...

【蓝桥杯】省赛:分糖果(思维/模拟)

思路 数据很小&#xff0c;直接暴力模拟。 有意思的是一个列表如何当成循环队列写&#xff1f;可以arr[(i1)%n]让他右边超出时自动回到开头。 code import os import sysn int(input()) arr list(map(int,input().split()))ans 0 while 1:arr1 arr.copy()for i in range…...

在 Go 语言中生成单元测试报告

在 Go 语言中生成单元测试报告&#xff0c;你可以使用 go test 命令配合一些参数来实现。以下是一些常用的方法和步骤&#xff1a; 基本测试&#xff1a;首先&#xff0c;确保你的项目已经编写了测试文件&#xff08;通常以 _test.go 结尾&#xff09;。然后&#xff0c;在项目…...

Metasploit Framework(MSF)使用教程与命令详解

Metasploit Framework&#xff08;简称MSF&#xff09;是一款功能强大的开源渗透测试工具&#xff0c;广泛应用于网络安全领域。它集成了大量的漏洞利用模块&#xff08;exploits&#xff09;、辅助模块&#xff08;auxiliary&#xff09;和载荷&#xff08;payloads&#xff0…...

进程间通信(1)——管道

1. 进程间通信简介 进程间通信&#xff08;Inter-Process Communication&#xff0c;IPC&#xff09;是指不同进程之间交换数据的机制。由于进程具有独立的地址空间&#xff0c;它们无法直接访问彼此的数据&#xff0c;因此需要IPC机制来实现信息共享、数据传递或同步操作。 …...

python基础8 单元测试

通过前面的7个章节&#xff0c;作者学习了python的各项基础知识&#xff0c;也学习了python的编译和执行。但在实际环境上&#xff0c;我们需要验证我们的代码功能符合我们的设计预期&#xff0c;所以需要结合python的单元测试类&#xff0c;编写单元测试代码。 Python有一个内…...

【正点原子K210连载】第七十六章 音频FFT实验 摘自【正点原子】DNK210使用指南-CanMV版指南

第七十六章 音频FFT实验 本章将介绍CanMV下FFT的应用&#xff0c;通过将时域采集到的音频数据通过FFT为频域。通过本章的学习&#xff0c;读者将学习到CanMV下控制FFT加速器进行FFT的使用。 本章分为如下几个小节&#xff1a; 32.1 maix.FFT模块介绍 32.2 硬件设计 32.3 程序设…...

【杂记二】git, github, vscode等

一、前言 暂时空着... 二、git 2.1 可能的疑问 1. VSCode 项目名和 GitHub 仓库名是否需要一致&#xff1f; 不需要一致。 VSCode 项目名&#xff08;也就是你本地的文件夹名字&#xff09;和 GitHub 仓库名可以不一样。 Git 是一个分布式版本控制系统&#xff0c;它主要关…...

《基于Spring Boot+Vue的智慧养老系统的设计与实现》开题报告

个人主页:@大数据蟒行探索者 一、研究背景及国内外研究现状 1.研究背景 根据1982年老龄问题世界大会联合国制定的标准,如果一个国家中超过65岁的老人占全国总人口的7%以上,或者超过60岁的老人占全国总人口的10%以上,那么这个国家将被定义为“老龄化社会”[1]。 随着国…...

ModBus TCP/RTU互转(主)(从)|| Modbus主动轮询下发的工业应用 || 基于智能网关的串口服务器进行Modbus数据收发的工业应用

目录 前言 一、ModBus TCP/RTU互转&#xff08;从&#xff09;及应用|| 1.1 举栗子 二、ModBus TCP/RTU互转&#xff08;主&#xff09; 2.1 举栗子 三、ModBus 主动轮询 3.1 Modbus主动轮询原理 3.2 Modbus格式上传与下发 3.2.1.设置Modbus主动轮询指令 3.2.2 设…...

【设计模式】3W 学习法深入剖析创建型模式:原理、实战与开源框架应用(含 Java 代码)

3W 学习法总结创建型模式&#xff08;附 Java 代码实战及开源框架应用&#xff09; 创建型模式主要关注 对象的创建&#xff0c;旨在提高代码的可复用性、可扩展性和灵活性。本文采用 3W 学习法&#xff08;What、Why、How&#xff09;&#xff0c;深入分析 五大创建型模式&am…...

Jobby、Quarkus 和 Spring Boot对比

Jobby、Quarkus 和 Spring Boot 是三种不同的 Java 框架&#xff0c;各自有不同的设计目标和适用场景。以下是对它们的详细对比&#xff1a; 1. 设计目标 框架设计目标Jobby轻量级的任务调度框架&#xff0c;专注于任务调度和执行。Quarkus面向云原生和 Kubernetes 的 Java 框…...

[代码规范]1_良好的命名规范能减轻工作负担

欢迎来到啾啾的博客&#x1f431;&#xff0c;一个致力于构建完善的Java程序员知识体系的博客&#x1f4da;&#xff0c;记录学习的点滴&#xff0c;分享工作的思考、实用的技巧&#xff0c;偶尔分享一些杂谈&#x1f4ac;。 欢迎评论交流&#xff0c;感谢您的阅读&#x1f604…...

【HarmonyOS Next之旅】DevEco Studio使用指南(三)

目录 1 -> 一体化工程迁移 1.1 -> 自动迁移 1.2 -> 手动迁移 1.2.1 -> API 10及以上历史工程迁移 1.2.2 -> API 9历史工程迁移 1 -> 一体化工程迁移 DevEco Studio从 NEXT Developer Beta1版本开始&#xff0c;提供开箱即用的开发体验&#xff0c;将SD…...

冯・诺依曼架构深度解析

一、历史溯源&#xff1a;计算机科学的革命性突破 1.1 前冯・诺依曼时代 在 1940 年代之前&#xff0c;计算机领域呈现 "百家争鸣" 的格局&#xff1a; 哈佛 Mark I&#xff08;1944&#xff09;&#xff1a;采用分离的指令存储与数据存储ENIAC&#xff08;1946&a…...

gralloc1_perform具体在干什么

gralloc1_perform 会在特定场景下通过 ioctl 调用&#xff0c;执行 缓存 (cache) 管理 和 内存映射 操作&#xff0c;确保 CPU 和 GPU 之间的数据一致性。 &#x1f4cc; 为什么需要对 cache 进行操作&#xff1f; 在 Android 系统中&#xff0c;CPU 和 GPU 通常共享 DDR 内存…...

安装配置Anaconda,配置VSCode

文章目录 Anaconda介绍下载Anaconda安装Anaconda换源创建一个新环境conda常用命令 VSCode环境配置 记录一下笔者收集的一些资料&#xff0c;不喜勿喷。 Anaconda介绍 Anaconda是一个用于科学计算的Python发行版&#xff0c;支持 Linux, Mac, Windows系统&#xff0c;提供了包管…...

【愚公系列】《高效使用DeepSeek》017-知识点思维导图生成

🌟【技术大咖愚公搬代码:全栈专家的成长之路,你关注的宝藏博主在这里!】🌟 📣开发者圈持续输出高质量干货的"愚公精神"践行者——全网百万开发者都在追更的顶级技术博主! 👉 江湖人称"愚公搬代码",用七年如一日的精神深耕技术领域,以"…...

【量化策略】网格交易策略

【量化策略】网格交易策略 &#x1f680;量化软件开通 &#x1f680;量化实战教程 技术背景与应用场景 网格交易策略是一种基于市场波动性的自动化交易方法&#xff0c;适用于震荡市场。它通过在预设的价格区间内设置多个买卖点&#xff0c;自动执行低买高卖的操作&#xf…...

C++ 语法之函数和函数指针

在上一章中 C 语法之 指针的一些应用说明-CSDN博客 我们了解了指针变量&#xff0c;int *p;取变量a的地址这些。 那么函数同样也有个地址&#xff0c;直接输出函数名就可以得到地址&#xff0c;如下&#xff1a; #include<iostream> using namespace std; void fun() …...

网络协议抓取与分析(SSL Pinning突破)

1. 网络协议逆向基础 1.1 网络协议分析流程 graph TD A[抓包环境配置] --> B[流量捕获] B --> C{协议类型} C -->|HTTP| D[明文解析] C -->|HTTPS| E[SSL Pinning突破] D --> F[参数逆向] E --> F F --> G[协议重放与模拟] 1.1.1 关键分析目标…...

蓝桥杯真题——洛谷Day13 找规律(修建灌木)、字符串(乘法表)、队列(球票)

目录 找规律 P8781 [蓝桥杯 2022 省 B] 修剪灌木 字符串 P8723 [蓝桥杯 2020 省 AB3] 乘法表 队列 P8641 [蓝桥杯 2016 国 C] 赢球票 找规律 P8781 [蓝桥杯 2022 省 B] 修剪灌木 思路&#xff1a;对某个特定的点来说有向前和向后的情况&#xff0c;即有向前再返回到该位置…...

【2025】基于Springboot + vue实现的毕业设计选题系统

项目描述 本系统包含管理员、学生、教师三个角色。 管理员角色&#xff1a; 用户管理&#xff1a;管理系统中所有用户的信息&#xff0c;包括添加、删除和修改用户。 配置管理&#xff1a;管理系统配置参数&#xff0c;如上传图片的路径等。 权限管理&#xff1a;分配和管理…...

JAVA并发编程 --- 补充内容

1 线程状态 1.1 状态介绍 当线程被创建并启动以后&#xff0c;它既不是一启动就进入了执行状态&#xff0c;也不是一直处于执行状态。线程对象在不同的时期有不同的状态。那么Java中的线程存在哪几种状态呢&#xff1f;Java中的线程 状态被定义在了java.lang.Thread.State枚…...

ADB三个模块介绍

ADB&#xff08;Android Debug Bridge&#xff09;是 Android 开发中非常重要的工具&#xff0c;它由 3 个主要模块 组成&#xff0c;分别是 ADB Client&#xff08;客户端&#xff09;、ADB Server&#xff08;服务端&#xff09; 和 ADB Daemon&#xff08;守护进程&#xff…...

【ArduPilot】Windows下使用Optitrack通过MAVProxy连接无人机实现定位与导航

Windows下使用Optitrack通过MAVProxy连接无人机实现定位与导航 配置动捕系统无人机贴动捕球配置无人机参数使用MAVProxy连接Optitrack1、连接无人机3、设置跟踪刚体ID4、校正坐标系5、配置IP地址&#xff08;非Loopback模式&#xff09;6、启动动捕数据推流 结语 在GPS信号弱或…...

qt 图像后处理的软件一

这是一个图像后处理软件刚刚&#xff0c;目前功能比较单一&#xff0c;后续会丰富常用的功能。 目前实现的功能有 1.导入图像 2图像可中心缩放&#xff08;右上角放大缩小&#xff0c;按钮及滚轮双重可控&#xff09;。 3.图像重置功能 软件界面如下。 代码放在我的资源里…...

Ardunio 连接OLED触摸屏(SSD1106驱动 4针 IIC通信)

一、准备工作 1、硬件 UNO R3 &#xff1a;1套 OLED触摸屏&#xff1a;1套 导线诺干 2、软件 arduino 二、接线 UNO R3OLED5VVCCGNDGNDA5SCLA4SDA 脚位如下图所示&#xff1a; Uno R3脚位图 触摸屏脚位图 查阅显示屏的驱动规格&#xff1a;通常显示屏驱动芯片有SSD1306,SH110…...

深度学习 第4章 数值计算和 Deepseek 的实践

第4章 数值计算和 Deepseek 的实践 章节概述 本章主要探讨了数值计算中的关键问题&#xff0c;这些问题在深度学习和机器学习中尤为重要。数值计算的核心挑战在于如何在有限的计算资源和精度限制下&#xff0c;高效且稳定地处理连续数学问题。本章首先讨论了溢出和下溢问题&a…...