树链剖分小结

这里没有水表

树链剖分是一个通过轻重链剖分、dfs序和线段树的使用,在有根树上维护路径和子树信息的有效算法
其预处理时间复杂度为\(O(nlog^2n)\),单次操作时间复杂度为\(O(log^2n)\),常数优秀
主要是防止自己忘记,所以只作简要说明,要学习的可以参考友链里大佬的博客

预处理

第一遍dfs

需要处理的数组有\(fa(父亲),son(重儿子),sz(子树大小)和dep(深度)\)

ll fa[N],son[N],sz[N],dep[N];
il void dfs1(int u,int f){sz[u]=1;fa[u]=f;dep[u]=dep[f]+1;for(RG int i=head[u];i;i=nxt[i]){RG int v=to[i];if(v==f)continue;dfs1(v,u);sz[u]+=sz[v];if(!son[u]||sz[v]>sz[son[u]])son[u]=v;}
}

第二遍dfs

需要处理的数组有\(w(原树节点在线段树节点上的编号),fw(线段树节点在原树节点上的编号),top(所在重链的顶部)\)
优先搜索重儿子,因为需要将重链上的节点放在线段树上相邻的位置

ll top[N],w[N],fw[N],cntw;
il void dfs2(int u,int f){top[u]=(son[fa[u]]==u)?top[fa[u]]:u;w[u]=++cntw;fw[w[u]]=u;if(son[u])dfs2(son[u],u);for(RG int i=head[u];i;i=nxt[i]){RG int v=to[i];if(v==f||v==son[u])continue;dfs2(v,u);}
}

其实到这里树链剖分就做完了

build线段树

线段树上节点的值通过\(fw\)数组和原树对应起来(这里以luogu树链剖分模板中的操作为例)

#define ls (i<<1)
#define rs (i<<1|1)
#define mid ((l+r)>>1)
ll sum[N<<2],lz[N<<2];
il void update(int i){sum[i]=(sum[ls]+sum[rs])%mod;}
il void build(ll i,ll l,ll r){if(l==r){sum[i]=val[fw[l]]%mod;return;}build(ls,l,mid);build(rs,mid+1,r);update(i);
}

维护子树信息

\(x\)为根的子树在线段树上表现出来的区间为\((w[x],w[x]+sz[x]-1)\)

修改

il void modify_tree(){RG int x=read(),k=read();modify(1,1,n,w[x],w[x]+sz[x]-1,k);
}

查询

il void query_tree(){RG int x=read();printf("%lld\n",query(1,1,n,w[x],w[x]+sz[x]-1));
}

维护路径信息

对于一条\(u->v\)的路径,我们根据之前的重链剖分可以将其分成不超过\(log(n)\)条重链,
每条重链分别在线段树上进行维护,这时重链的合并也就成为维护路径信息的一大难点

修改

il void modify_road(){RG int u=read(),v=read();RG ll k=read();while(top[u]!=top[v]){if(dep[top[u]]<dep[top[v]])swap(u,v);modify(1,1,n,w[top[u]],w[u],k);u=fa[top[u]];}if(dep[u]>dep[v])swap(u,v);modify(1,1,n,w[u],w[v],k);
}

查询

il void query_road(){RG int u=read(),v=read();RG ll ret=0;while(top[u]!=top[v]){if(dep[top[u]]<dep[top[v]])swap(u,v);ret=(ret+query(1,1,n,w[top[u]],w[u]))%mod;u=fa[top[u]];}if(dep[u]>dep[v])swap(u,v);printf("%lld\n",(ret+query(1,1,n,w[u],w[v]))%mod);
}

luogu P3384 【模板】树链剖分

囊括了上面的操作.

#include<algorithm>
#include<iostream>
#include<cstdlib>
#include<iomanip>
#include<cstring>
#include<complex>
#include<vector>
#include<cstdio>
#include<string>
#include<bitset>
#include<cmath>
#include<queue>
#include<stack>
#include<map>
#include<set>
#define mp make_pair
#define pb push_back
#define RG register
#define il inline
using namespace std;
typedef unsigned long long ull;
typedef vector<int>VI;
typedef long long ll;
typedef double dd;
const dd eps=1e-10;
const int N=100010;
const int M=50010*2;
il ll read(){RG ll data=0,w=1;RG char ch=getchar();while(ch!='-'&&(ch<'0'||ch>'9'))ch=getchar();if(ch=='-')w=-1,ch=getchar();while(ch<='9'&&ch>='0')data=data*10+ch-48,ch=getchar();return data*w;
}ll n,m,r,mod,val[N];
ll head[N],nxt[N<<1],to[N<<1],cnt;
il void add(int u,int v){to[++cnt]=v;nxt[cnt]=head[u];head[u]=cnt;
}ll fa[N],son[N],sz[N],dep[N];
il void dfs1(int u,int f){sz[u]=1;fa[u]=f;dep[u]=dep[f]+1;for(RG int i=head[u];i;i=nxt[i]){RG int v=to[i];if(v==f)continue;dfs1(v,u);sz[u]+=sz[v];if(!son[u]||sz[v]>sz[son[u]])son[u]=v;}
}ll top[N],w[N],fw[N],cntw;
il void dfs2(int u,int f){top[u]=(son[fa[u]]==u)?top[fa[u]]:u;w[u]=++cntw;fw[w[u]]=u;if(son[u])dfs2(son[u],u);for(RG int i=head[u];i;i=nxt[i]){RG int v=to[i];if(v==f||v==son[u])continue;dfs2(v,u);}
}#define ls (i<<1)
#define rs (i<<1|1)
#define mid ((l+r)>>1)
ll sum[N<<2],lz[N<<2];
il void update(int i){sum[i]=(sum[ls]+sum[rs])%mod;}
il void build(ll i,ll l,ll r){if(l==r){sum[i]=val[fw[l]]%mod;return;}build(ls,l,mid);build(rs,mid+1,r);update(i);
}il void pushdown(ll i,ll l,ll r){if(!lz[i])return;sum[ls]=(sum[ls]+lz[i]*(mid-l+1)%mod)%mod;sum[rs]=(sum[rs]+lz[i]*(r-mid)%mod)%mod;lz[ls]=(lz[ls]+lz[i])%mod;lz[rs]=(lz[rs]+lz[i])%mod;lz[i]=0;
}il void modify(ll i,ll l,ll r,ll x,ll y,ll k){if(x<=l&&r<=y){sum[i]=(sum[i]+k*(r-l+1)%mod)%mod;lz[i]=(lz[i]+k)%mod;return;}pushdown(i,l,r);if(x<=mid)modify(ls,l,mid,x,y,k);if(y>=mid+1)modify(rs,mid+1,r,x,y,k);update(i);
}il ll query(ll i,ll l,ll r,ll x,ll y){if(x<=l&&r<=y)return sum[i]%mod;pushdown(i,l,r);RG ll s=0;if(x<=mid)s=query(ls,l,mid,x,y)%mod;if(y>=mid+1)s=(s+query(rs,mid+1,r,x,y))%mod;return s;
}il void modify_tree(){RG int x=read(),k=read();modify(1,1,n,w[x],w[x]+sz[x]-1,k);
}il void query_tree(){RG int x=read();printf("%lld\n",query(1,1,n,w[x],w[x]+sz[x]-1));
}il void modify_road(){RG int u=read(),v=read();RG ll k=read();while(top[u]!=top[v]){if(dep[top[u]]<dep[top[v]])swap(u,v);modify(1,1,n,w[top[u]],w[u],k);u=fa[top[u]];}if(dep[u]>dep[v])swap(u,v);modify(1,1,n,w[u],w[v],k);
}il void query_road(){RG int u=read(),v=read();RG ll ret=0;while(top[u]!=top[v]){if(dep[top[u]]<dep[top[v]])swap(u,v);ret=(ret+query(1,1,n,w[top[u]],w[u]))%mod;u=fa[top[u]];}if(dep[u]>dep[v])swap(u,v);printf("%lld\n",(ret+query(1,1,n,w[u],w[v]))%mod);
}int main()
{n=read();m=read();r=read();mod=read();for(RG int i=1;i<=n;i++)val[i]=read()%mod;for(RG int j=1,u,v;j<n;j++){u=read();v=read();add(u,v);add(v,u);}dfs1(r,0);dfs2(r,0);build(1,1,n);for(RG int i=1,opt;i<=m;i++){opt=read();if(opt==1)modify_road();if(opt==2)query_road();if(opt==3)modify_tree();if(opt==4)query_tree();}return 0;
}

[SDOI2011]染色

询问树上的路径有多少条颜色段,区间修改
记录区间左颜色段,右颜色段,和颜色段数,合并重链时需要留意

#include<algorithm>
#include<iostream>
#include<cstdlib>
#include<iomanip>
#include<cstring>
#include<complex>
#include<vector>
#include<cstdio>
#include<string>
#include<bitset>
#include<cmath>
#include<queue>
#include<stack>
#include<map>
#include<set>
#define mp make_pair
#define pb push_back
#define RG register
#define il inline
using namespace std;
typedef unsigned long long ull;
typedef vector<int>VI;
typedef long long ll;
typedef double dd;
const dd eps=1e-10;
const int mod=1e9+7;
const int N=100100;
const int M=50010*2;
il ll read(){RG ll data=0,w=1;RG char ch=getchar();while(ch!='-'&&(ch<'0'||ch>'9'))ch=getchar();if(ch=='-')w=-1,ch=getchar();while(ch<='9'&&ch>='0')data=data*10+ch-48,ch=getchar();return data*w;
}il void file(){freopen("a.in","r",stdin);freopen("a.out","w",stdout);
}int n,m,c[N];char ch;
int head[N],nxt[N<<1],to[N<<1],cnt;
il void add(int u,int v){to[++cnt]=v;nxt[cnt]=head[u];head[u]=cnt;
}int fa[N],son[N],sz[N],dep[N];
void dfs1(int u){sz[u]=1;for(RG int i=head[u];i;i=nxt[i]){RG int v=to[i];if(v==fa[u])continue;fa[v]=u;dep[v]=dep[u]+1;dfs1(v);sz[u]+=sz[v];if(!son[u]||sz[v]>sz[son[u]])son[u]=v;}
}int top[N],w[N],fw[N],cntw;
void dfs2(int u,int tp){top[u]=tp;w[u]=++cntw;fw[w[u]]=u;if(son[u])dfs2(son[u],tp);for(RG int i=head[u];i;i=nxt[i]){RG int v=to[i];if(v==fa[u]||v==son[u])continue;dfs2(v,v);}
}#define ls (i<<1)
#define rs (i<<1|1)
#define mid ((l+r)>>1)
int sum[N<<2],lc[N<<2],rc[N<<2],s[N<<2];
il void update(int i){sum[i]=sum[ls]+sum[rs]-(rc[ls]==lc[rs]);lc[i]=lc[ls];rc[i]=rc[rs];
}
void build(int i,int l,int r){if(l==r){sum[i]=1;lc[i]=rc[i]=c[fw[l]];return;}build(ls,l,mid);build(rs,mid+1,r);update(i);
}
il void pushdown(int i){if(!s[i])return;sum[ls]=sum[rs]=1;s[ls]=s[rs]=lc[ls]=rc[ls]=lc[rs]=rc[rs]=s[i];s[i]=0;
}void modify(int i,int l,int r,int x,int y,int w){if(x<=l&&r<=y){sum[i]=1;s[i]=lc[i]=rc[i]=w;return;}pushdown(i);if(x<=mid)modify(ls,l,mid,x,y,w);if(y>mid)modify(rs,mid+1,r,x,y,w);update(i);
}int query(int i,int l,int r,int x,int y,int &L,int &R){if(x<=l&&r<=y){L=lc[i];R=rc[i];return sum[i];}pushdown(i);if(x<=mid&&y<=mid)return query(ls,l,mid,x,y,L,R);if(x>mid&&y>mid)return query(rs,mid+1,r,x,y,L,R);RG int lr=0,rl=0,s=0;s=query(ls,l,mid,x,y,L,lr)+query(rs,mid+1,r,x,y,rl,R);if(lr==rl&&lr)s--;return s;
}il void modify_road(){RG int u=read(),v=read(),k=read();while(top[u]!=top[v]){if(dep[top[u]]<dep[top[v]])swap(u,v);modify(1,1,n,w[top[u]],w[u],k);u=fa[top[u]];}if(dep[u]>dep[v])swap(u,v);modify(1,1,n,w[u],w[v],k);
}il void query_road(){RG int u=read(),v=read(),tu=-1,tv=-1,l=0,r=0,sum=0,ret;while(top[u]!=top[v]){if(dep[top[u]]<dep[top[v]])swap(u,v),swap(tu,tv);ret=query(1,1,n,w[top[u]],w[u],l,r);sum+=ret;if(r==tu)sum--;tu=l;u=fa[top[u]];}if(dep[u]>dep[v])swap(u,v),swap(tu,tv);ret=query(1,1,n,w[u],w[v],l,r);sum+=ret;if(l==tu)sum--;if(r==tv)sum--;printf("%d\n",sum);
}int main()
{n=read();m=read();for(RG int i=1;i<=n;i++)c[i]=read();for(RG int i=1,u,v;i<n;i++){u=read();v=read();add(u,v);add(v,u);}dfs1(1);dfs2(1,1);build(1,1,n);for(RG int i=1;i<=m;i++){ch=0;while(ch!='C'&&ch!='Q')ch=getchar();if(ch=='C')modify_road();else query_road();}return 0;
}

[NOI2015]软件包管理器

其实就是弱化版的模板。

#include<algorithm>
#include<iostream>
#include<cstdlib>
#include<iomanip>
#include<cstring>
#include<complex>
#include<vector>
#include<cstdio>
#include<string>
#include<bitset>
#include<cmath>
#include<queue>
#include<stack>
#include<map>
#include<set>
#define mp make_pair
#define pb push_back
#define RG register
#define il inline
using namespace std;
typedef unsigned long long ull;
typedef vector<int>VI;
typedef long long ll;
typedef double dd;
const dd eps=1e-10;
const int mod=1e9+7;
const int N=100010;
const int M=50010*2;
il ll read(){RG ll data=0,w=1;RG char ch=getchar();while(ch!='-'&&(ch<'0'||ch>'9'))ch=getchar();if(ch=='-')w=-1,ch=getchar();while(ch<='9'&&ch>='0')data=data*10+ch-48,ch=getchar();return data*w;
}il void file(){freopen("a.in","r",stdin);freopen("a.out","w",stdout);
}int n,q;char ch[10];
int head[N],nxt[N<<1],to[N<<1],cnt;
il void add(int u,int v){to[++cnt]=v;nxt[cnt]=head[u];head[u]=cnt;
}int sz[N],fa[N],dep[N],son[N];
void dfs1(int u){sz[u]=1;for(RG int i=head[u];i;i=nxt[i]){RG int v=to[i];if(v==fa[u])continue;fa[v]=u;dep[v]=dep[u]+1;dfs1(v);sz[u]+=sz[v];if(!son[u]||sz[v]>sz[son[u]])son[u]=v;}
}int top[N],w[N],fw[N],cntw;
void dfs2(int u,int tp){top[u]=tp;w[u]=++cntw;fw[w[u]]=u;if(son[u])dfs2(son[u],tp);for(RG int i=head[u];i;i=nxt[i]){RG int v=to[i];if(v==fa[u]||v==son[u])continue;dfs2(v,v);}
}#define ls (i<<1)
#define rs (i<<1|1)
#define mid ((l+r)>>1)
int sum[2][N<<2],lz[N<<2];
//初始时lz=-1
il void update(int i){sum[0][i]=sum[0][ls]+sum[0][rs];sum[1][i]=sum[1][ls]+sum[1][rs];
}
il void pushdown(int i,int l,int r){if(lz[i]==-1)return;lz[ls]=lz[rs]=lz[i];sum[lz[ls]^1][ls]=0;sum[lz[ls]][ls]=mid-l+1;sum[lz[rs]^1][rs]=0;sum[lz[rs]][rs]=r-mid;lz[i]=-1;
}
il void build(int i,int l,int r){lz[i]=-1;if(l==r){sum[0][i]=1;sum[1][i]=0;return;}build(ls,l,mid);build(rs,mid+1,r);update(i);
}il void modify(int i,int l,int r,int x,int y,int k){if(x<=l&&r<=y){lz[i]=k;sum[k][i]=r-l+1;sum[k^1][i]=0;return;}pushdown(i,l,r);if(x<=mid)modify(ls,l,mid,x,y,k);if(y>mid)modify(rs,mid+1,r,x,y,k);update(i);
}il int query(int i,int l,int r,int x,int y,int k){if(x<=l&&r<=y)return sum[k][i];pushdown(i,l,r);RG int s=0;if(x<=mid)s=query(ls,l,mid,x,y,k);if(y>mid)s+=query(rs,mid+1,r,x,y,k);return s;
}il void modify_tree(int u,int k){modify(1,1,n,w[u],w[u]+sz[u]-1,k);
}
il void query_tree(int u,int k){printf("%d\n",query(1,1,n,w[u],w[u]+sz[u]-1,k));
}il void modify_road(int u,int v,int k){while(top[u]!=top[v]){if(dep[top[u]]<dep[top[v]])swap(u,v);modify(1,1,n,w[top[u]],w[u],k);u=fa[top[u]];}if(dep[u]>dep[v])swap(u,v);modify(1,1,n,w[u],w[v],k);
}il void query_road(int u,int v,int k){RG int s=0;while(top[u]!=top[v]){if(dep[top[u]]<dep[top[v]])swap(u,v);s+=query(1,1,n,w[top[u]],w[u],k);u=fa[top[u]];}if(dep[u]>dep[v])swap(u,v);printf("%d\n",s+query(1,1,n,w[u],w[v],k));
}int main()
{n=read();for(RG int i=2;i<=n;i++){fa[i]=read()+1;add(i,fa[i]);add(fa[i],i);}dfs1(1);dfs2(1,1);build(1,1,n);q=read();for(RG int i=1,x;i<=q;i++){scanf("%s",ch+1);x=read()+1;if(ch[1]=='i')query_road(1,x,0),modify_road(1,x,1);else query_tree(x,1),modify_tree(x,0);}return 0;
}

[JLOI2014]松鼠的新家

本来是树上差分来着...被我拿树剖来练手了。

#include<algorithm>
#include<iostream>
#include<cstdlib>
#include<iomanip>
#include<cstring>
#include<complex>
#include<vector>
#include<cstdio>
#include<string>
#include<bitset>
#include<cmath>
#include<queue>
#include<stack>
#include<map>
#include<set>
#define mp make_pair
#define pb push_back
#define RG register
#define il inline
using namespace std;
typedef unsigned long long ull;
typedef vector<int>VI;
typedef long long ll;
typedef double dd;
const dd eps=1e-10;
const int mod=1e9+7;
const int N=300010;
const int M=50010*2;
il ll read(){RG ll data=0,w=1;RG char ch=getchar();while(ch!='-'&&(ch<'0'||ch>'9'))ch=getchar();if(ch=='-')w=-1,ch=getchar();while(ch<='9'&&ch>='0')data=data*10+ch-48,ch=getchar();return data*w;
}il void file(){freopen("a.in","r",stdin);freopen("a.out","w",stdout);
}int n,a[N];
int head[N],nxt[N<<1],to[N<<1],cnt;
il void add(int u,int v){to[++cnt]=v;nxt[cnt]=head[u];head[u]=cnt;
}int sz[N],fa[N],son[N],dep[N];
void dfs1(int u){sz[u]=1;for(RG int i=head[u];i;i=nxt[i]){RG int v=to[i];if(v==fa[u])continue;dep[v]=dep[u]+1;fa[v]=u;dfs1(v);sz[u]+=sz[v];if(!son[u]||sz[son[u]]<sz[v])son[u]=v;}
}int top[N],w[N],fw[N],cntw;
void dfs2(int u,int tp){top[u]=tp;w[u]=++cntw;fw[w[u]]=u;if(son[u])dfs2(son[u],tp);for(RG int i=head[u];i;i=nxt[i]){RG int v=to[i];if(v==fa[u]||v==son[u])continue;dfs2(v,v);}
}#define ls (i<<1)
#define rs (i<<1|1)
#define mid ((l+r)>>1)
ll sum[N<<2],lz[N<<2];
il void update(int i){sum[i]=sum[ls]+sum[rs];}
il void pushdown(int i,int l,int r){if(!lz[i])return;sum[ls]+=lz[i]*(mid-l+1);sum[rs]+=lz[i]*(r-mid);lz[ls]+=lz[i];lz[rs]+=lz[i];lz[i]=0;
}il void modify(int i,int l,int r,int x,int y,int k){if(x<=l&&r<=y){lz[i]+=k;sum[i]+=k*(r-l+1);return;}pushdown(i,l,r);if(x<=mid)modify(ls,l,mid,x,y,k);if(y>mid)modify(rs,mid+1,r,x,y,k);update(i);
}il ll query(int i,int l,int r,int x,int y){if(x<=l&&r<=y)return sum[i];pushdown(i,l,r);RG ll s=0;if(x<=mid)s=query(ls,l,mid,x,y);if(y>mid)s+=query(rs,mid+1,r,x,y);return s;
}il void modify_road(int u,int v){while(top[u]!=top[v]){if(dep[top[u]]<dep[top[v]])swap(u,v);modify(1,1,n,w[top[u]],w[u],1);u=fa[top[u]];}if(dep[u]>dep[v])swap(u,v);modify(1,1,n,w[u],w[v],1);
}int main()
{n=read();for(RG int i=1;i<=n;i++)a[i]=read();for(RG int i=1,u,v;i<n;i++){u=read();v=read();add(u,v);add(v,u);}dfs1(1);dfs2(1,1);for(RG int i=2;i<=n;i++){modify_road(a[i-1],a[i]);modify(1,1,n,w[a[i]],w[a[i]],-1);}for(RG int i=1;i<=n;i++)printf("%lld\n",query(1,1,n,w[i],w[i]));return 0;
}

未完待续......(其实是我写的题太少了)

转载于:https://www.cnblogs.com/cjfdf/p/8470788.html

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

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

相关文章

OCR系列——文本检测任务

1. 简介 文本检测任务是找出图像或视频中的文字位置。不同于目标检测任务&#xff0c;目标检测不仅要解决定位问题&#xff0c;还要解决目标分类问题。 目标检测和文本检测同属于“定位”问题。但是文本检测无需对目标分类&#xff0c;并且文本形状复杂多样。 当前所说的文本…

关于ORACLE 语句中,IN 超过1000个的解决方法

在ORACLE SELECT 语句中 IN 的数据如果超过 1000&#xff0c;就会出错&#xff0c;解决方法也很简单&#xff0c;以C#代码为例&#xff1a; 1、先写一个方法&#xff0c;接收2个参数 参数1&#xff1a;接收 IN里面的数据&#xff0c;如&#xff1a;a1,a2,...a2000 &#xff1b;…

9个提高代码运行效率的小技巧你知道几个?

我们写程序的目的就是使它在任何情况下都可以稳定工作。一个运行的很快但是结果错误的程序并没有任何用处。在程序开发和优化的过程中&#xff0c;我们必须考虑代码使用的方式&#xff0c;以及影响它的关键因素。通常&#xff0c;我们必须在程序的简洁性与它的运行速度之间做出…

STM32——按键

STM32——按键 宗旨&#xff1a;技术的学习是有限的&#xff0c;分享的精神是无限的。 一、GPIO工作模式 1、当I/O端口配置为输入时&#xff1a; 输出缓冲器被禁止 施密特触发输入被激活 根据输入配置(上拉&#xff0c;下拉或浮动)的不同&#xff0c;弱上拉和下拉电阻被连接 …

【Flask模板】include标签

# include标签&#xff1a;1. 这个标签相当于是直接将指定的模版中的代码复制粘贴到当前位置。2. include标签&#xff0c;如果想要使用父模版中的变量&#xff0c;直接用就可以了&#xff0c;不需要使用with context。3. include的路径&#xff0c;也是跟import一样&#xff0…

深度学习——模型的压缩和加速

1. 简介 随着深度学习发展&#xff0c;越来越多的模型被发现和应用&#xff0c;模型的体量也越来越大&#xff0c;出现了模型过于庞大和参数冗余的问题。同时&#xff0c;移动端对模型的需求也是越轻量越好&#xff0c;因此&#xff0c;模型压缩和加速技术应运而生。 模型压缩…

干货,记一次解决录音杂音问题

最近在项目上遇到一个问题&#xff0c;也不能说是最近项目上的问题了&#xff0c;是之前一直存在的问题&#xff0c;但是对项目没什么影响&#xff0c;所以我就不怎么理会&#xff0c;直到最近&#xff0c;同事说这个杂音已经影响到了项目的开发&#xff0c;所以今天花了一天时…

3.5.2 冒泡排序类

那么&#xff0c;我们就以冒泡排序为例&#xff0c;把它改造成一个类。首先&#xff0c;单击菜单&#xff0c;“项目”&#xff0d;“添加类”&#xff0c;添加一个BubbleSort.cs类文件。IDE自动为我们创建如下代码&#xff1a; usingSystem;usingSystem.Collections.Generic;u…

STM32——串口通信

STM32——串口通信 宗旨&#xff1a;技术的学习是有限的&#xff0c;分享的精神是无限的。 一、异步串口通信协议 STM32 的串口非常强大&#xff0c;它不仅支持最基本的通用串口同步、异步通信&#xff0c;还具有 LIN 总线功能&#xff08;局域互联网&#xff09;、IRDA 功能&…

操作系统——经典同步问题

1、概念 1.1 进程同步与互斥 在多道程序环境下&#xff0c;进程是并发执行的&#xff08;并发执行是指两个或多个事件在某段时间间隔内并发&#xff09;&#xff0c;不同进程之间存在着不同的相互制约关系。为了协调进程之间的相互制约关系&#xff0c;引入了进程同步的概念。…

JavaScript权威指南(第5版)pdf

下载地址&#xff1a;网盘下载内容简介编辑第5版针对Ajax和Web 2.0技术进行了全新的改版。和上一版相比&#xff0c;更新的内容较多&#xff0c;总体上接近整个篇幅的1/2&#xff0c;而这也正是本书姗姗来迟的原因之一。具体来说&#xff0c;第5版在以下部分有所更新&#xff1…

操作系统——死锁(银行家算法)

1、概述 1.1 死锁 死锁是多个进程因竞争资源而造成的一种僵局&#xff08;互相等待&#xff09;&#xff0c;若无外力作用&#xff0c;这些进程都将无法向前推进。 1.2 死锁产生的原因和条件 原因&#xff1a;&#xff08;1&#xff09;竞争资源&#xff1b;&#xff08;2&…

STM32——库函数开发小结

STM32——库函数开发小结 宗旨&#xff1a;技术的学习是有限的&#xff0c;分享的精神是无限的。 基本上所有外设都有以下几类寄存器&#xff1a;【CR/DR/SR】 &#xff08;1&#xff09;控制寄存器 xxx_CR(Control/Configuration Register)&#xff1a;这类寄存器是用来配置…

过年不回家,难受不

看电视&#xff0c;特别怕看到离别的情节&#xff0c;最近看「山海情」&#xff0c;也刚好看到。本着剧情不透露原则&#xff0c;我就不说里面的内容了。小时候&#xff0c;经历的都只能算是小别离了。小时候喜欢去外婆家&#xff0c;在外婆家不用干繁重的农活&#xff0c;父母…

lodap问题集锦

1、分页打印时&#xff0c;同一行显示在不同页内 &#xff0c;调整行分页粒度 LODOP.SET_PRINT_STYLEA(0, "TableRowThickNess", 40); 转载于:https://www.cnblogs.com/feihusurfer/p/8482180.html

系统管理员节日 网民的感恩日

11月8日 “记者节"、 9月10日“教师节”、 5月12日“国际护士节”&#xff0c;职业节日的设立会提升公众对该职业的关注程度&#xff0c;该职业的形象也往往因节日而凸显&#xff0c;而作为让这个世界变平的&#xff0c;在幕后默默付出的系统管理者的心声又有谁听到了呢&a…

操作系统——内存管理

1、内存基本概念 1.1 主要功能 内存空间的分配与回收&#xff1b;地址转换内存保护&#xff1a;使用上下限寄存器或者重定位寄存器和界地址寄存器内存扩充&#xff1a;交换和覆盖内容共享 2、内存的分配与回收 2.1 连续分配方式 连续分配方式是指为一个用户程序分配一个连续…

解决一个驱动代码解耦合问题

之前解决的项目LCD设备兼容问题&#xff0c;在 a.c 文件里面定义了一个变量&#xff0c;然后在 b.c 里面使用 extern声明引用这个变量&#xff0c;通过这种方法可以在b.c中使用在a.c 里面初始化的变量。但是这中情况就会引起一个问题&#xff0c;就是驱动代码之间耦合了&#x…

STM32——DMA

STM32——DMA 宗旨&#xff1a;技术的学习是有限的&#xff0c;分享的精神是无限的。 DMA 是为CPU分担数据转移的工作。因为DMA的存在CPU才被解放出来&#xff0c;它可以在 DMA 转移数据的过程中同时进行数据运算、响应中断&#xff0c;大大提高效率。 1、DMA工作分析 数据传…