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

2023济南大学acm新生赛题解

通过答题情况的难度系数:

签到:ACI

铜牌题:BG

银牌题:EF

金牌题:DHJKO

赛中暂未有人通过:LMNP

A - A+B Problem

直接根据公式计算就行。

#include<stdio.h>
int main(){int a,b;scanf("%d %d",&a,&b);printf("%d\n",a*b+a+b);return 0;
}

 C - 五分钟慢题

         输出当前时间五分钟之后。

#include<bits/stdc++.h>
using namespace std;
int main(){int t;cin>>t;while(t--){int h,m;scanf("%d:%d",&h,&m);m+=5;h+=m/60;m%=60;h%=24;printf("%02d:%02d\n",h,m);}
}

 I - 你的母校

        输出“济南大学”四个字总共多少笔画,可能很多同学不知道“学”是8画,比赛途中很多同学交28,正确答案应该是29.

#include <bits/stdc++.h>
using namespace std;
int main(){printf("29\n");
}

B - A=B Problem

         判断等式是否成立,容易发现,先进行乘法和除法操作,再进行加减,但是乘法和除法操作对结果没有影响,所以只需要判断等式两边进行加减的次数即可。

#include <bits/stdc++.h>
using namespace std;
char a[1005];
int main(){int t;cin>>t;while(t--){scanf("%s",a+1);int len=strlen(a+1);int op;//'='的位置int sub=0,add=0;for(int i=1;i<=len;i++){if(a[i]=='='){op=i;break;}else if(a[i]=='-') sub++;else if(a[i]=='+') add++;}int sub1=0,add1=0;for(int i=op+1;i<=len;i++){if(a[i]=='-') sub1++;else if(a[i]=='+') add1++;}sub-add==sub1-add1?printf("1\n"):printf("0\n");}
}

 G - 荡蛛丝博士被生物电整红温了

        给两个区间,每个区间各取一个值,保证加起来后的数十进制分解下各位数的最大值最大。容易想到,区间大小大于等于10就可得到最大值9,故可先算出左手的伤害范围+右手的伤害范围的区间,然后进行循环,循环次数最大十次即可得到答案。

#include<bits/stdc++.h>
using namespace std;
int solve(long long x){int mx=0;while(x!=0){int k=x%10;mx=max(mx,k);x/=10;}return mx;
}
int main(){int t;cin>>t;while(t--){long long a,b,c,d;cin>>a>>b>>c>>d;a+=c;b+=d;if(b-a>=10) cout<<"9"<<endl;else{int mx=0;for(long long i=a;i<=b;i++){mx=max(mx,solve(i));}cout<<mx<<endl;}}
}

 E - 小w智取切糕

         有一个切糕的长宽高分别为 x, y, z,摊主想把这块切糕切割成  x* y* z个边长为 1 的小正方体,保证切的次数最少。每次尽量往中间下刀,然后摞起来,一直重复这个过程就行。

#include<bits/stdc++.h>
using namespace std;
int solve(int x){int ans=0;while(x!=1){ans+=1;x=(x+1)/2;}return ans;
}
int main(){int t;cin>>t;while(t--){int x,y,z;cin>>x>>y>>z;int ans=0;ans+=solve(x);ans+=solve(y);ans+=solve(z);cout<<ans<<endl;}
}

F - ym的刀

         比赛中,直到最后一场才知道谁是赢家,且每场小局也是如此,故只需要判断最后一场谁赢了,谁就是赢家。当然也可以暴力枚举X,Y,直到找到满足题意得X和Y。

#include<bits/stdc++.h>
using namespace std;
char a[10005];
int main(){int t;cin>>t;while(t--){int n;cin>>n;scanf("%s",a+1);if(a[n]=='O') cout<<"OG wins!\n";else cout<<"LGD wins!\n";}
}

D - 两小时块题

        判断矩阵中是否存在x行y列的子矩阵,且子矩阵中数字全为1.

        暴力写法就是,枚举若干个x行y列的子矩阵,每个子矩阵进行枚举求和,判断是否等于x*y,时间复杂度O(n^{4}),如果在赛中写的这种暴力代码,加上一些优化,本题也是可以过的,按道理是不能过的。下面介绍O(n^{3})做法和O(n^{2})做法

O(n^{3})做法:每次枚举,固定x行,枚举列,例如:

求和ans,当遇到0的格子,ans=0,然后继续往后枚举,直到出现ans=x*y。下面附上赛中,电子2302谢家仪的代码进行参考:

#include<stdio.h>
#include<string.h>
int a[501][501];
int main(){int t,x,y,n,m,i,j,k,sum,flag=0;scanf("%d",&t);while(t--){memset(a,0,sizeof(a));flag=0;scanf("%d%d",&n,&m);for(i=0;i<n;i++){for(j=0;j<m;j++){scanf("%d",&a[i][j]);}}sum=0;scanf("%d%d",&x,&y);for(i=0;i<n&&flag==0;i++){for(j=0;j<m&&flag==0;j++){for(k=i;k<i+x;k++){sum+=a[k][j];if(a[k][j]==0) {sum=0;break;}}if(sum==x*y){printf("yes\n");flag=1;}if(j==m-1&&sum!=0) sum=0;}}if(flag==0) printf("no\n");}return 0;
}

O(n^{2})做法:如果你了解二位前缀和的话,这题应该可以很快就出。可参考这篇博客:二维前缀和详解_二维矩阵前缀-CSDN博客

#include<bits/stdc++.h>
using namespace std;
int a[505][505],pre[505][505];
int main(){int t;cin>>t;while(t--){int n,m;cin>>n>>m;for(int i=1;i<=n;i++){for(int j=1;j<=m;j++){cin>>a[i][j];pre[i][j]=0;}}int x,y;cin>>x>>y;for(int i=1;i<=n;i++){for(int j=1;j<=m;j++){pre[i][j]=pre[i-1][j]+pre[i][j-1]-pre[i-1][j-1]+a[i][j];}}bool ok=false;for(int i=1;i<=n;i++){for(int j=1;j<=m;j++){if(i-x>=0&&j-y>=0){int ans=pre[i][j]-pre[i-x][j]-pre[i][j-y]+pre[i-x][j-y];if(ans==x*y){ok=true;}}}}ok==true?cout<<"yes"<<endl:cout<<"no"<<endl;}
}

H - 这题真的不难

        由题意可知,n-1条锁链形成了一棵树,每次操作都能删除一个叶子结点,先者都不想操作后使得编号 k变成叶子,不然后者赢得胜利,故删除叶子,只有两种情况,一种是一开始k本身就是叶子,第二种是进行n-2次操作后删除k。

#include<bits/stdc++.h>
using namespace std;
int a[105];
int main(){int t;cin>>t;while(t--){int n,k;cin>>n>>k;for(int i=1;i<=n;i++) a[i]=0;for(int i=1;i<=n-1;i++){int x,y;cin>>x>>y;a[x]++;a[y]++;}if(a[k]==1) cout<<"FuRongWang"<<endl;else{if(n&1) cout<<"MaMaShengDe"<<endl;else cout<<"FuRongWang"<<endl;}}
}

J - Syan移动

         对数组进行两种操作,一种是左移X位,一种是右移X位,每次操作都进行移位,每组询问数据时间复杂度大概O(n*m),最坏的情况能达到1e10,这种情况下肯定跑不出来。

        显然,多次的不同左右移动操作,会有相互抵消的情况,定义初始状态为右移flag=0的情况,进行右移X位,即flag=flag+X,进行左移X位,即flag=flag-X,最后得到数组需要右移flag位,右移n,2*n,3*n,...相当于数组未移动,所以最后记得对flag进行取模操作,或者在累加操作中进行取模操作。

        赛中,有些同学进行移位累加的操作,没有考虑到flag爆int的情况,导致答案错误。

#include<bits/stdc++.h>
using namespace std;
int a[100005];
int pre[100005];
int main(){int t;cin>>t;while(t--){int n;cin>>n;for(int i=1;i<=n;i++) cin>>a[i];int m;cin>>m;int state=0;int ans=0;while(m--){char op;int x;cin>>op>>x;if(op=='-') ans-=x;else ans+=x;ans%=n;}if(ans>0){for(int i=n-ans+1;i<=n;i++) printf("%d ",a[i]);for(int i=1;i<=n-ans;i++) printf("%d ",a[i]);}else if(ans==0){for(int i=1;i<=n;i++) printf("%d ",a[i]);}else if(ans<0){ans*=-1;for(int i=ans+1;i<=n;i++) printf("%d ",a[i]);for(int i=1;i<=ans;i++) printf("%d ",a[i]);}printf("\n");}
}

K - Syan的加法

         对数组进行两种操作,加法操作和翻转操作。在写这题之前,如果你了解差分,可能就不用太多的思考。

        定义:假设有原数组 a[ ] = {a_1,a_2,a_3...a_n},现构造出一个数组 b[ ] = {b_1,b_2,b_3...b_n},使得 a_i = b_1 + b_2 + b_3 + ... + b_i,那么 b[ ] 就称为 a[ ] 的差分,a[ ] 就称为 b[ ] 的前缀和。可以发现,差分与前缀和是逆运算。

        一维差分可以快速地实现如下操作:区间修改,时间复杂度为 O(1)

假如现在要将原数列 a[ ] 区间 [L,R] 上的每个数都加上 x,那么通过上述定义可以知道:

  • 第一个受影响的差分数组中的元素为 b[L],所以令 b[L]+=x,那么后面数列元素在计算过程中都会加上 x。
  • 最后一个受影响的差分数组中的元素为 b[R],所以令 b[R+1]−=x,那么可以保证不会影响到 R 之后数列元素的计算。

        这样一来,就不必对区间内每一个数进行处理,只需处理两个端点即可,翻转操作中途不用进行,最后进行翻转就行,不过中间需要记录翻转的状态,然后判断对哪段区间进行操作。

#include<bits/stdc++.h>
using namespace std;
int a[100005];
int pre[100005];
int main(){int t;cin>>t;while(t--){int n;cin>>n;for(int i=1;i<=n;i++) cin>>a[i];int m;cin>>m;int state=0;while(m--){int op,l,r;cin>>op;if(op==1){cin>>l>>r;if(state==0){pre[l]+=1,pre[r+1]-=1;}else{pre[n-r+1]+=1,pre[n-l+2]-=1;}}else{state^=1;}}for(int i=1;i<=n;i++) pre[i]+=pre[i-1],a[i]+=pre[i];if(state==0){for(int i=1;i<=n;i++){i==1?printf("%d",a[i]):printf(" %d",a[i]);}}else{for(int i=n;i>=1;i--){i==n?printf("%d",a[i]):printf(" %d",a[i]);}}for(int i=1;i<=n+1;i++) pre[i]=0;printf("\n"); }
}

 O - 微风与笔尖与春日花抄

         每次查询,可以暴力枚举以每个方格为起点,然后往八个方向进行枚举匹配。赛中有些同学理解题目可能有误,出现的字串只能是任意一个方向延伸任意长度,将这段路径上的字符按顺序连接,不会出现拐弯的情况。

#include<bits/stdc++.h>
using namespace std;
char a[35][35];
char b[105];
int dir[8][2]={0,1,0,-1,1,0,-1,0,1,-1,1,1,-1,1,-1,-1};
int main(){int n;cin>>n;int m;cin>>m;for(int i=1;i<=n;i++) scanf("%s",a[i]+1);for(int i=1;i<=m;i++){scanf("%s",b+1);int len=strlen(b+1);bool ok=false;for(int i=1;i<=n;i++){for(int j=1;j<=n;j++){if(a[i][j]==b[1]){for(int k=0;k<8;k++){int x=i,y=j;bool flag=true;for(int m=1;m<=len;m++){if(x>=1&&x<=n&&y>=1&&y<=n&&b[m]==a[x][y]){}else flag=false;x+=dir[k][0];y+=dir[k][1];}if(flag){ok=true;break;}}}}}ok==true?printf("yes\n"):printf("no\n");}
}

L - Syan的最大金币数(2)

         由题意可得,整个迷宫被障碍物分成了几个区域,如果起点和终点不在一个区域,将无法离开迷宫;如果在一个区域,区域中,不管Syan从哪个点出发,都能到达整个区域的所有点,然后选择一个金币数最大的格子,最后离开迷宫。故这题可以先使用bfs或者dfs找出所有区域的最大值,然后离线查询即可。

#include<bits/stdc++.h>
using namespace std;
int a[1005][1005];
int vis[1005][1005];
int dir[4][2]={1,0,0,1,-1,0,0,-1};
int n,m;
int num=0;
void dfs(int x,int y){for(int i=0;i<4;i++){int X=x+dir[i][0],Y=y+dir[i][1];if(X>=1&&X<=n&&Y>=1&&Y<=n&&a[X][Y]!=-1&&vis[X][Y]==0){vis[X][Y]=vis[x][y];dfs(X,Y);}}
}
void bfs(int x,int y){queue<pair<int,int> >q;q.push({x,y});while(!q.empty()){pair<int,int> st = q.front();q.pop();for(int i=0;i<4;i++){int nx=st.first+dir[i][0],ny=st.second+dir[i][1];if(nx>=1&&nx<=n&&ny<=n&&ny>=1&&a[nx][ny]!=-1&&vis[nx][ny]==0){vis[nx][ny]=vis[st.first][st.second];q.push({nx,ny});}}}
}
int mx[1000005];
int main(){int t;cin>>t;while(t--){scanf("%d%d",&n,&m);for(int i=1;i<=n;i++){for(int j=1;j<=n;j++){cin>>a[i][j];vis[i][j]=0;}}int cnt=0;for(int i=1;i<=n;i++){for(int j=1;j<=n;j++){if(a[i][j]!=-1&&vis[i][j]==0){vis[i][j]=++cnt;bfs(i,j);//或者dfs(i,j)}}}for(int i=0;i<=cnt;i++) mx[i]=-1;for(int i=1;i<=n;i++){for(int j=1;j<=n;j++){if(vis[i][j]!=0) mx[vis[i][j]]=max(mx[vis[i][j]],a[i][j]);}}while(m--){int x1,y1,x2,y2;cin>>x1>>y1>>x2>>y2;if(vis[x1][y1]!=vis[x2][y2]) cout<<"-1\n";else cout<<mx[vis[x1][y1]]<<endl;}}
}

M - 色彩与轮回与夜幕之国

         给为0的格子进行上色,保证相邻格子不会出现相同颜色。首先,出现了相邻格子且都是1的情况,肯定不能满足题意,无法实现目标。其他情况就是可以实现目标的情况,显然,有如下几种情况需要改变相邻位置为0的颜色:

1. 出现若干个相邻位置为0的情况,且若干个位置形成一条直线,需要一种颜色;

例如:\begin{bmatrix} 0 &0 &0 &0 \end{bmatrix}或者\begin{bmatrix} 0\\ 0\\ 0\\ 0 \end{bmatrix}

2. 出现"三角形"相邻位置为0的情况,需要两种颜色;

例如:\begin{bmatrix} &0 \\ 0 & 0 \end{bmatrix}或者\begin{bmatrix} 0& \\ 0& 0 \end{bmatrix}或者\begin{bmatrix} 0&0 \\ & 0 \end{bmatrix}或者\begin{bmatrix} 0&0 \\ 0& \end{bmatrix}

3. 出现"正方形"相邻位置为0的情况,需要三种颜色;

例如:\begin{bmatrix} 0&0 \\ 0 & 0 \end{bmatrix}

优先级为情况3>情况2>情况1.

#include<bits/stdc++.h>
using namespace std;
int a[105][105];
int dir[8][2]={-1,0,1,0,0,-1,0,1,-1,1,-1,-1,1,1,1,-1};
int main(){int t;cin>>t;while(t--){int n,m;cin>>n>>m;int ans=0;for(int i=1;i<=n;i++){for(int j=1;j<=m;j++){cin>>a[i][j];}}bool ok=true;bool ok1=false,ok2=false,ok3=false;for(int i=1;i<=n;i++){for(int j=1;j<=m;j++){for(int k=0;k<8;k++){int x=i+dir[k][0],y=j+dir[k][1];if(x>=1&&y>=1&&x<=n&&y<=m){if(a[x][y]&&a[i][j]) ok=false;if(!a[x][y]&&!a[i][j]){ok1=true;if(x==i&&y-j==1){if(x-1>=1&&!a[x-1][j]){ok2=true;if(!a[x-1][y]) ok3=true;}if(x+1<=n&&!a[x+1][j]){ok2=true;if(!a[x+1][y]) ok3=true;}}if(x==i&&y-j==-1){if(x-1>=1&&!a[x-1][j]){ok2=true;if(!a[x-1][y]) ok3=true;}if(x+1<=n&&!a[x+1][j]){ok2=true;if(!a[x+1][y]) ok3=true;}}}}}}}if(!ok) cout<<"-1"<<endl;else{if(ok3) cout<<"3"<<endl;else if(ok2) cout<<"2"<<endl;else if(ok1) cout<<"1"<<endl;else cout<<"0"<<endl;}}
}

N - 吉他与孤独与蓝色星球

        由题意可知,需要在区间[l,r]中找到x阶升调乐段,容易直到x最大为r-l+1,故区间[l,r]中可以组成升调乐段的最小段树为mina,如果x>=mina,说明可以组成x阶升调乐段,反之不可组成,现在得问题就是找到mina。显然,找到区间[l,r]中的最长递减(严格递减)子序列,你会发现递减(严格递减)子序列,不管怎么进行组合,都只能组成单个音符的乐段,故这题只需要找到区间[l,r]中的最长递减(严格递减)子序列,其长度就是区间[l,r]中可以组成升调乐段的最小段树mina。

        算法的合理性其实很清楚,找到最长递减(严格递减)子序列,剩余的其他数,每个都可以往最长递减(严格递减)子序列其中的某个位置后面塞。

#include<bits/stdc++.h>
using namespace std;
int a[1005],f[1005];
int main(){int n,m;cin>>n>>m;for(int i=1;i<=n;i++) scanf("%d",&a[i]);while(m--){int x,y,z,s=1;scanf("%d%d%d",&x,&y,&z);for(int i=x;i<=y;i++){f[i]=1;for(int j=x;j<i;j++) if(a[i]<a[j]) f[i]=max(f[i],f[j]+1),s=max(s,f[i]);}puts(s<=z?"yes":"no");}
}

P - 守护与救济与星海泛舟

        给一个无向图,每条边都有边权,每次查询结点x到结点y中的所有路径,找出到达结点y路径上的最大边权最小。

        首先,我们可以先把所有的边按照从小到大排序,遍历所有边,对每条边的端点u,v,通过并查集将他们表示相连,每次连完后判断起点和终点是否在同一集合里,如果在则输出这次的边权,即为答案。算法的合理性其实很清楚,贪心地从最短的边开始找起,一直到起点终点相连,最后加入的边是此次路径内的边的最大值,就是答案。

        但是本题有m次查询,每次都重复这个步骤,时间肯定不允许,故可以预处理出最小生成树,然后利用倍增法求树中两个结点的最近公共祖先LCA的思路(可参考博客84-倍增法求最近公共祖先LCA(超清晰的思路) - 知乎 (zhihu.com)),保存每个结点往上跳2^i下的路径最大值。

#include<bits/stdc++.h>
using namespace std;
const int Max=2e6+5;
int n,m,k;
struct node1{int to;int val;
};
vector<node1>v[Max];int vis[Max];
void init(int n){for(int i=1;i<=n;i++) vis[i]=i;
}
int father(int x){if(x==vis[x]) return x;return vis[x]=father(vis[x]);
}
void link(int x,int y){vis[father(x)]=vis[father(y)];
}
struct node{int u,v,z;
};
node mp[Max];
int dep[Max];
int fa[Max][25],fa1[Max][25];
void dfs(int fat,int u,int s){fa[u][0]=fat;fa1[u][0]=s;dep[u]=dep[fat]+1;for(auto tmp:v[u]){if(tmp.to!=fat){dfs(u,tmp.to,tmp.val);}}
}
int main(){scanf("%d%d%d",&n,&m,&k);for(int i=1;i<=m;i++){int u,vv,w;scanf("%d%d%d",&u,&vv,&w);mp[i]={u,vv,w};}sort(mp+1,mp+1+m,[&](node a,node b){return a.z<b.z;});init(n);for(int i=1;i<=m;i++){if(father(mp[i].u)!=father(mp[i].v)){link(mp[i].u,mp[i].v);v[mp[i].u].push_back({mp[i].v,mp[i].z});v[mp[i].v].push_back({mp[i].u,mp[i].z});}}dfs(0,1,0);for(int i=1;i<=20;i++){for(int j=1;j<=n;j++){fa[j][i]=fa[fa[j][i-1]][i-1];fa1[j][i]=max(fa1[fa[j][i-1]][i-1],fa1[j][i-1]);}}while(k--){int x,y;scanf("%d%d",&x,&y);if(dep[x]>dep[y]) swap(x,y);int ans=0;int num=dep[y]-dep[x];for(int i=20;i>=0;i--){if(num>=(1<<i)){num-=(1<<i);ans=max(ans,fa1[y][i]);y=fa[y][i];}}for(int i=20;i>=0;i--){if(fa[x][i]!=fa[y][i]){ans=max(ans,fa1[y][i]);ans=max(ans,fa1[x][i]);y=fa[y][i];x=fa[x][i];}}if(x!=y) ans=max(ans,fa1[y][0]),ans=max(ans,fa1[x][0]);printf("%d\n",ans);}
}

相关文章:

2023济南大学acm新生赛题解

通过答题情况的难度系数&#xff1a; 签到&#xff1a;ACI 铜牌题&#xff1a;BG 银牌题&#xff1a;EF 金牌题&#xff1a;DHJKO 赛中暂未有人通过&#xff1a;LMNP A - AB Problem 直接根据公式计算就行。 #include<stdio.h> int main(){int a,b;scanf("%…...

docker-compose安装教程

1.确认docker-compose是否安装 docker-compose -v如上图所示表示未安装&#xff0c;需要安装。 如上图所示表示已经安装&#xff0c;不需要再安装&#xff0c;如果觉得版本低想升级&#xff0c;也可以继续安装。 2.离线安装 下载docker-compose安装包&#xff0c;上传到服务…...

【rabbitMQ】rabbitMQ用户,虚拟机地址(添加,修改,删除操作)

rabbitMQ的下载&#xff0c;安装和配置 https://blog.csdn.net/m0_67930426/article/details/134892759?spm1001.2014.3001.5502 rabbitMQ控制台模拟收发消息 https://blog.csdn.net/m0_67930426/article/details/134904365?spm1001.2014.3001.5502 目录 用户 添加用户…...

Python高级算法——动态规划

Python中的动态规划&#xff1a;高级算法解析 动态规划是一种解决多阶段决策问题的数学方法&#xff0c;常用于优化问题。它通过将问题分解为子问题&#xff0c;并在解决这些子问题的基础上构建全局最优解。在本文中&#xff0c;我们将深入讲解Python中的动态规划&#xff0c;…...

MySQL在Centos7环境安装

说明&#xff1a; • 安装与卸载中&#xff0c;⽤⼾全部切换成为root&#xff0c;⼀旦 安装&#xff0c;普通⽤⼾能使⽤的 1. 卸载不要的环境 [roothcss-ecs-1036 ~]# ps ajx |grep mariadb # 先检查是否有mariadb存在 13134 14844 14843 13134 pts/0 14843 S 1005 0:00 gr…...

halcon视觉缺陷检测常用的6种方法

一、缺陷检测综述 缺陷检测是视觉需求中难度最大一类需求,主要是其稳定性和精度的保证。首先常见缺陷:凹凸、污点瑕疵、划痕、裂缝、探伤等。常用的手法有六大金刚(在halcon中的ocv和印刷检测是针对印刷行业的检测,有对应算子封装): 1.blob+特征 2.blob+差分+特征 3.光度…...

openGauss学习笔记-151 openGauss 数据库运维-备份与恢复-物理备份与恢复之gs_basebackup

文章目录 openGauss学习笔记-151 openGauss 数据库运维-备份与恢复-物理备份与恢复之gs_basebackup151.1 背景信息151.2 前提条件151.3 语法151.4 示例151.5 从备份文件恢复数据 openGauss学习笔记-151 openGauss 数据库运维-备份与恢复-物理备份与恢复之gs_basebackup 151.1 …...

报错:Uncaught ReferenceError: Cannot access ‘l‘ before initialization

在文件 .babelrc 或 babel.config.js &#xff0c;webpack.config.js 下配置 .babel 或 babel.config.js "plugins": ["babel/plugin-transform-runtime" ] webpack.config.js&#xff0c;详见 Webpack target module.exports {target: [web, es5], }...

计算机视觉-机器学习-人工智能顶会 会议地址

计算机视觉-机器学习-人工智能顶会 会议地址 最近应该要整理中文资料的参考文献&#xff0c;很多会议文献都需要补全会议地点&#xff08;新国标要求&#xff09;。四处百度感觉也挺麻烦的&#xff0c;而且没有比较齐全的网站可以搜索。因此自己整理了一下计算机视觉-机器学习…...

784. 字母大小写全排列

字母大小写全排列 描述 : 给定一个字符串 s &#xff0c;通过将字符串 s 中的每个字母转变大小写&#xff0c;我们可以获得一个新的字符串。 返回 所有可能得到的字符串集合 。以 任意顺序 返回输出。 题目 : LeetCode 784.字母大小写全排列 : 784. 字母大小写全排列 分析…...

HarmonyOS鸿蒙应用开发——HTTP网络访问与封装

文章目录 基本使用封装参考 基本使用 鸿蒙应用发起HTTP请求的基本使用&#xff0c;如下&#xff1a; 导入http模块创建httpRequest对象发起http请求&#xff0c;并处理响应结果 第一、导入http模块&#xff1a; import http from ohos.net.http第二、创建httpRequest对象&a…...

vscode 编写爬虫爬取王者荣耀壁纸

网上关于爬虫大部分教程和编辑器用的都不是vscode &#xff0c;此教程用到了vscode、Python、bs4、requests。 vscode配置Python安装环境可以看看这个大佬的教程 03-vscode安装和配置_哔哩哔哩_bilibili vscode配置爬虫环境可以参考这个大佬的教程【用Vscode实现简单的python…...

spring boot + uniapp 微信公众号 jsapi 支付

后端支付类 package com.ruoyi.coupon.payment;import com.google.gson.Gson; import com.ruoyi.coupon.payment.dto.PayParamJsapiDto; import com.ruoyi.coupon.payment.dto.RefundParam; import com.ruoyi.coupon.service.ICouponConfigService; import com.wechat.pay.jav…...

【数学建模】《实战数学建模:例题与讲解》第九讲-时间序列分析(含Matlab代码)

【数学建模】《实战数学建模&#xff1a;例题与讲解》第九讲-时间序列分析&#xff08;含Matlab代码&#xff09; 基本概念确定性时间序列分析方法平稳时间序列模型ARIMA模型季节性序列 习题8.11. 题目要求2.解题过程3.程序4.结果 习题8.21. 题目要求2.解题过程3.程序4.结果 习…...

大话数据结构-查找-有序表查找

注&#xff1a;本文同步发布于稀土掘金。 3 有序表查找 3.1 折半查找 折半查找&#xff08;Binary Search&#xff09;技术&#xff0c;又称为二分查找&#xff0c;它的前提是线性表中的记录必须是关键码有序&#xff08;通常从小到大有序&#xff09;&#xff0c;线性表必须…...

Qt实现二维码生成和识别

一、简介 QZxing开源库: 生成和识别条码和二维码 下载地址&#xff1a;https://gitcode.com/mirrors/ftylitak/qzxing/tree/master 二、编译与使用 1.下载并解压&#xff0c;解压之后如图所示 2.编译 打开src目录下的QZXing.pro&#xff0c;选择合适的编译器进行编译 最后生…...

MyBatisX插件

MyBatisX插件 MyBatis-Plus为我们提供了强大的mapper和service模板&#xff0c;能够大大的提高开发效率。 但是在真正开发过程中&#xff0c;MyBatis-Plus并不能为我们解决所有问题&#xff0c;例如一些复杂的SQL&#xff0c;多表联查&#xff0c;我们就需要自己去编写代码和SQ…...

《C++20设计模式》学习笔记---原型模式

C20设计模式 第 4 章 原型模式4.1 对象构建4.2 普通拷贝4.3 通过拷贝构造函数进行拷贝4.4 “虚”构造函数4.5 序列化4.6 原型工厂4.7 总结4.8 代码 第 4 章 原型模式 考虑一下我们日常使用的东西&#xff0c;比如汽车或手机。它们并不是从零开始设计的&#xff0c;相反&#x…...

SpringBootAdmin设置邮件通知

如果你想要在Spring Boot Admin中配置邮件通知&#xff0c;可以按照以下步骤进行操作&#xff1a; 添加邮件通知的依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-mail</artifactId> </dep…...

深度解析IP应用场景API:提升风险控制与反欺诈能力

前言 在当今数字化时代&#xff0c;网络安全和用户数据保护成为企业日益关注的焦点。IP应用场景API作为一种强大的工具&#xff0c;不仅能够在线调用接口获取IP场景属性&#xff0c;而且具备识别IP真人度的能力&#xff0c;为企业提供了卓越的风险控制和反欺诈业务能力。本文将…...

Java连接数据库增删改查-MyBatis

准备工作&#xff1a; 1.创建一个springboot项目&#xff0c;并添加四个依赖 分别是&#xff0c;MyBatis的启动依赖和安装依赖&#xff0c;SQL的依赖&#xff0c;测试依赖&#xff0c;如下&#xff1a; 2.然后创建一张至少两条数据的表 &#xff08;表可以用各种图形化工具创…...

在国内,现在月薪1万是什么水平?

看到网友发帖问&#xff1a;现在月薪1W是什么水平&#xff1f; 在现如今的情况下&#xff0c;似乎月薪过万这个标准已经成为衡量个人能力的一个标准了&#xff0c;尤其是现在互联网横行的时代&#xff0c;好像年入百万&#xff0c;年入千万就应该是属于大众的平均水平。 我不是…...

【Python网络爬虫入门教程1】成为“Spider Man”的第一课:HTML、Request库、Beautiful Soup库

Python 网络爬虫入门&#xff1a;Spider man的第一课 写在最前面背景知识介绍蛛丝发射器——Request库智能眼镜——Beautiful Soup库 第一课总结 写在最前面 有位粉丝希望学习网络爬虫的实战技巧&#xff0c;想尝试搭建自己的爬虫环境&#xff0c;从网上抓取数据。 前面有写一…...

燕千云汇联易联袂出击:护航医企合规,丝滑内外协作

&#x1f449; 如想详细了解燕千云医药行业快速实施包&#xff08;ITFA&#xff09;&#xff0c;可继续阅读详细内容&#xff1a; 文/玉娇龙 一. 医药行业数字化挑战 医药研发从基础研究到最终注册上市的整个生命周期长则需要10多年&#xff0c;短则需要6-7年&#xff0c;在漫长…...

【线性代数与矩阵论】Jordan型矩阵

Jordan型矩阵 2023年11月3日 #algebra 文章目录 Jordan型矩阵1. 代数重数与几何重数2. Jordan块与Jordan标准型2.1 最小多项式与Jordan标准型2.2 两类重要矩阵 3. 矩阵的Jordan分解3.1 Jordan分解的应用 下链 1. 代数重数与几何重数 在对向量做线性变换时&#xff0c;向量空间…...

laravel的ORM 对象关系映射

Laravel 中的 ORM&#xff08;Eloquent ORM&#xff09;是 Laravel 框架内置的一种对象关系映射系统&#xff0c;用于在 PHP 应用中与数据库进行交互。Eloquent 提供了一种优雅而直观的语法&#xff0c;使得开发者可以使用面向对象的方式进行数据库查询和操作。 定义模型&…...

049:VUE 引入jquery的方法和配置

第049个 查看专栏目录: VUE ------ element UI 专栏目标 在vue和element UI联合技术栈的操控下&#xff0c;本专栏提供行之有效的源代码示例和信息点介绍&#xff0c;做到灵活运用。 &#xff08;1&#xff09;提供vue2的一些基本操作&#xff1a;安装、引用&#xff0c;模板使…...

Qt设置类似于qq登录页面

头文件 #ifndef WIDGET_H #define WIDGET_H#include <QWidget> #include <QWindow> #include <QIcon> #include <QLabel> #include <QMovie> #include <QLineEdit> #include <QPushButton>QT_BEGIN_NAMESPACE namespace Ui { class…...

【GDB】

GDB 1. GDB调试器1.1 前言1.2 GDB编译程序1.3 启动GDB1.4 载入被调试程序1.5 查看源码1.6 运行程序1.7 断点设置1.7.1 通过行号设置断点1.7.2 通过函数名设置断点1.7.3 通过条件设置断点1.7.4 查看断点信息1.7.5 删除断点 1.8 单步调试1.9 2. GDB调试core文件2.1 设定core文件的…...

深入了解Java Duration类,对时间的精细操作

阅读建议 嗨&#xff0c;伙计&#xff01;刷到这篇文章咱们就是有缘人&#xff0c;在阅读这篇文章前我有一些建议&#xff1a; 本篇文章大概6000多字&#xff0c;预计阅读时间长需要5分钟。本篇文章的实战性、理论性较强&#xff0c;是一篇质量分数较高的技术干货文章&#x…...