PTA校赛算法题十道java、C++详解

目录

7-1 专1 签到

7-2 专2 令人眼花缭乱的字符串

7-3 专3 VALORANT 

7-4 专4 吃蛋糕

7-5 专5 Game 

7-6 专6 二进制回文串 

7-7 专7 度假

7-8 专8 括号匹配Plus 

7-9 专9 生成最少叶子树

7-10 专10 禁止超速


这篇文章是基于我们前不久的校赛写的,校赛给的题解都是C++,我很想写一份完整的java版本,但是能力不够,大家可以看看逻辑,感兴趣的朋友可以写一份java题解在评论区,我替你交一下再来回复你你是不是满分通过了的具体情况。很希望有喜欢刷题的小伙伴和我交流Java版的题解。在我学成归来后,我会把这篇文章出一份完全的java题解。

 7-1 专1 签到

欢迎来2023年程序设计竞赛签到。输入正整数n,请你输出n遍2023。

输入格式:

一个正整数n

输出格式:

输出n遍2023,一个数占一行,结尾没有空行。

#include<bits/stdc++.h>
using namespace std;
int main (){
int n;
cin>>n;
for(int i=1;i<n;i++){
cout<<"2023\n";
}
cout<<"2023";
return 0;
}

不知道为什么,这道题同样的逻辑思路Java得到的分就不全面或者说超出运行时间,C和C++就满分过了。希望有知道的大佬评论区解答一下。 

7-2 专2 令人眼花缭乱的字符串

请你来帮小X做一个简单的工作,那就是:帮他数一数给出的字符串里面,出现了多少次“HEBAU”。


注:五个字母连续排列才能算作出现一次,忽略大小写!!!

输入格式:

输入只有一行字符串(可能包含空格)。

输出格式:

只需要输出“HEBAU”出现的次数即可。

输入样例1:

HEBAUhebauHeBau

输出样例1:

3

输入样例2:

HEbauLJY,heBauEuzer。hebauGS HEBAU

输出样例2:

4

代码长度限制

16 KB

时间限制

400 ms

内存限制

64 MB

import java.util.Scanner;public class Main {public static void main(String[] args) {Scanner input = new Scanner(System.in);String str = input.nextLine().toUpperCase(); // 将输入的字符串转换为大写int count = 0;for (int i = 0; i <= str.length() - 5; i++) {if (str.substring(i, i + 5).equals("HEBAU")) {count++;}}System.out.println(count);}
}

7-3 专3 VALORANT 

这道题我非常想用java写,但是无法运行成功,希望有感兴趣的大佬能用Java写一写,我可以复制到PTA帮你运行看能否满分通过。

我们的好朋友cyp最近一些日子里开始沉迷于瓦洛兰特,但他最近有些许的忙碌,总是无暇顾及游戏,但他一旦有时间,肯定是会来上一局的。


下面给出cyp一天的事务安排时间表(从凌晨0:00到午夜23:59,给出的时间段都是有事务在身的,表上没写的时间即为空闲时间)。
假设空闲时间不低于60min,他就可以来一局紧张刺激的瓦洛兰特(并且同一段空闲时间他不会玩第二局游戏),请你帮他算算,这一天可以打多少局VALORANT。

输入格式:

输入在一行中给出1个不超过1000的整数A,表示cyp今天安排了n件事务要做。
接下来n行,给出每件事务的工作时间(从早到晚一次给出,无重复时间段)。

输出格式:

输出一行,只需要输出cyp今天可以玩几局VALORANT即可

输入样例:

在这里给出一组输入。例如:

8
00:00:00 - 01:00:05
01:00:05 - 04:30:00
05:30:00 - 06:30:00
06:30:00 - 07:10:58
07:10:59 - 08:00:00
08:00:00 - 09:00:00
13:00:00 - 18:00:00
18:00:00 - 19:00:00

输出样例:

在这里给出相应的输出。例如:

3

代码长度限制

16 KB

时间限制

400 ms

内存限制

64 MB

#include<stdio.h>
int main()
{
int start=0,end=0;
int n;//几个时间段
scanf("%d",&n);
int s1,s2,s3,e1,e2,e3;
int miao;
int m=0;
while(n--)
{
scanf("%d:%d:%d - %d:%d:%d",&s1,&s2,&s3,&e1,&e2,&e3);
end=s1*3600+s2*60+s3;
if(end-start>=60*60)
{
m++;
}
start=e1*3600+e2*60+e3;
}
if(23*3600+59*60+59-start>=3600)
{
m++;
}
printf("%d",m);
return 0;
}

 7-4 专4 吃蛋糕

ACM俱乐部的xzh大佬过生日了,但他必须且只能吃大小为 K 个单位的蛋糕。由于生日蛋糕的规格有限,现在你只能选择一块大小为 2 的非负整数幂(即 1,2,4,8,16,⋯)的蛋糕进行购买。
为了满足xzh的需求,可以采取对半切割的方式,将一块大小为 N 个单位的蛋糕切成两块大小为 2N​​ 个单位的蛋糕。
由于资金有限,你需要求出所需的蛋糕大小的最小值和最小切割次数。

输入格式:

第一行,一个正整数 K,表示xzh所需的蛋糕大小。

输出格式:

输出两个整数,分别表示蛋糕大小的最小值和所需的最少切割次数。

输入样例:

7

输出样例:

8 3

样例说明

获得7个单位的蛋糕至少需要大小为8的蛋糕,首先切一刀得到两个4个单位的蛋糕,将一个4个单位的蛋糕切一刀获得两个2个单位的蛋糕,将一个两个单位的蛋糕切一刀获得两个1个单位的蛋糕。最终K=7=4+2+1。

数据范围

对于 100% 的数据,1≤K≤1×106。

代码长度限制

16 KB

时间限制

400 ms

内存限制

64 MB

#include<bits/stdc++.h>
using namespace std;
int main(){
int k, sum = 1, cnt = 0;
cin>>k;
while(sum < k)sum *= 2, cnt++;
cout<<sum<<" ";
while(k % 2 == 0)k /= 2, cnt--;
cout<<cnt;
return 0;
}

7-5 专5 Game 

聪明的LJY发明了一个小游戏,他在地上花了n个格子里面有数字的格子,所有格子从左到右依次排列。

规则:
(1)玩家可以选择任意一个位置,并走到这个格子上。
(2)玩家需要根据自己脚下格子中的数字向右走这个数字个数的格子。
(3)当走过最后一个格子时游戏结束。
(4)玩家所经过(停留过的格子)数字的总和为游戏得分,包含起始位置。

作为发明这个游戏的发明者,LJY不想自己输给其他玩家,请你帮助他得到这个游戏最高的分数。

输入格式:

每个测试用例的第一行包含一个整数n(1≤n≤2×106) ———— 数组 a 的长度。
接下来一行包含n个整数a1​,a2​,…,an​(1≤ai​≤109) ———— 数组 a 的元素。

输出格式:

输出一个数字 ———— 表示LJY可以获得的最大得分。请注意,LJY可以选择任何1到n之间的起始位置,以最大化他的结果。

输入样例:

在这里给出一组输入。例如:

5
7 3 1 2 3

输出样例:

在这里给出相应的输出。例如:

7

###说明

n=5 且 a = [7,3,1,2,3],则可能的选项如下:
LJY选择 i=1。游戏过程:i=1⟶+7​8。游戏的得分是:a1​=7。
LJY选择 i=2。游戏过程:i=2⟶+3​5⟶+3​8。游戏的得分是:a2​+a5​=6。
LJY选择 i=3。游戏过程:i=3⟶+1​4⟶+2​6。游戏的得分是:a3​+a4​=3。
LJY选择 i=4。游戏过程:i=4⟶+2​6。游戏的得分是:a4​=2。
LJY选择 i=5。游戏过程:i=5⟶+3​8。游戏的得分是:a5​=3。

代码长度限制

16 KB

时间限制

400 ms

内存限制

64 MB

#include <bits/stdc++.h>
using namespace std;
#define qc std::ios::sync_with_stdio(0);
long long a[2000001];
long long dp[2000001];
int main() {
qc;
cin.tie(0);
int n;
long long ans = 0;
cin >> n;
for (int i = 1; i <= n; i++) {
cin >> a[i];
}
for (int i = n; i >= 1; i--) {
if (i + a[i] <= n)
dp[i] = a[i] + dp[i + a[i]];
else
dp[i] = a[i];
ans = max(ans, dp[i]);
}
cout << ans << endl;
}

7-6 专6 二进制回文串 

这是一道思维题。
一个长度为 n 的二进制字符串 s (只含 0,1)。一个数字 x,如果存在长度为 n 并且含有 x 个 1 的二进制字符串 l ,使得 si​⊕li​ 为回文串(⊕ 为异或符号,1⊕1=0 ,0⊕0=0,0⊕1=1),则称这个数字 x 是 good 数字。
输出长度为 n+1 的二进制字符串 t ,如果 i 是 good 数字,则 ti​为1,否则 ti​ 为 0 。

输入格式:

每个测试包含多个测试用例。
第一行包含测试用例的数量 t (1≤t≤105)。
其后是每个测试用例的描述。
每个测试用例的第一行包含一个整数 n (1≤n≤105)。
每个测试用例的第二行包含一个长度为 n 的二进制字符串 s 。
保证所有测试用例中 n 的总和不超过105。

输出格式:

对于每个测试用例,输出一行一个长度为 n+1 的二进制字符串的答案。

输入样例:

在这里给出一组输入。例如:

4
6
101011
4
1010
8
10001101
1
1

输出样例:

在这里给出相应的输出。例如:

0010100
00100
001010100
11

说明

第一个示例。
t2​=1 ,我们可以选择 l=010100,然后字符串 s 变成 111111,这是一个回文串。
t4​=1 ,我们可以选择 l=101011。
对于所有其他 i ,都没有对应的 l,所以剩下的符号是 0 ,输出 0010100。

代码长度限制

16 KB

时间限制

400 ms

内存限制

64 MB

#include<bits/stdc++.h>
using namespace std;
int T,n,len,d,bd,ans[100005];
char ch[100005];
int main()
{
scanf("%d",&T);
while(T--)
{
scanf("%d%s",&n,ch+1),d=bd=0;
for(int i=0;i<=n;++i) ans[i]=0;
for(int i=1;i*2<=n;++i)
{
if(ch[i]==ch[n+1-i]) ++d;
else ++bd;
}
for(int i=0;i<=d;++i)
{
ans[bd+i*2]=1;
if(n%2) ans[bd+i*2+1]=1;
}
for(int i=0;i<=n;++i)
{
cout<<ans[i];
}
cout<<endl;
}
return 0;
}

 7-7 专7 度假

ML同学来到野外准备度过难得的假期。“ML,15分钟后来开会!”。雅兴被电话打断了的ML同学只好朝学校跑去。他跑到学校需要过一条河,河的宽度为L,但是唯一的桥离他非常远,因此他必须想其他的办法过河。幸运的是,河中有许多半径不同的圆形荷叶(可能会有重叠),ML可以踩着这些荷叶跳到河对岸去。

我们可以在这条河中建立直角坐标系,在坐标系中,ML同学所在一侧河岸的纵坐标y=0,学校一侧河岸的纵坐标y=L。ML通过观察得到了所有荷叶中心的坐标以及荷叶的半径,且已知他可以跳K单位长度。

如果两片荷叶之间的最短距离小于等于K,那他就可以在这两片荷叶之间跳跃;如果有一片荷叶距河岸的最短距离小于等于K,那他就可以在河岸和这片荷叶之间跳跃;ML在河岸上可以随意移动。问ML同学最终能不能到达对岸(赶上开会)。

画图4_17(1).jpg

输入格式:

每个输入文件包含多组数据。
第一行,包含一个正整数 T,代表该输入文件中所含的数据组数。
接下来是 T 组数据,每组数据的格式如下: 第一行包含三个正整数 N,L,K,两个数之间以一个空格分开,分别代表河流中荷叶的数量,河流的宽度和ML同学可以跳跃的距离。
接下来的 N 行,每行包含三个整数 x,y,r,两个数之间以一个空格分开,表示荷叶中心坐标为 (x,y),半径为r。

输出格式:

T 行,分别对应 T 组数据的答案,如果在第 i 组数据中,ML 能到达河对岸,则输出 Yes,如果不能,则输出 No

输入样例:

在这里给出一组输入。例如:

3
1 4 1
2 2 1
1 5 1
2 2 1
3 10 2
1 4 2
4 2 1
6 7 2

输出样例:

在这里给出相应的输出。例如:

Yes
No
Yes

数据范围

对于 20% 的数据,T=1,1≤L,K≤104,坐标的绝对值不超过 104。
对于 100% 的数据,1≤N≤1×103,1≤L,K≤109,T≤20,坐标的绝对值不超过 109。

代码长度限制

16 KB

时间限制

1000 ms

内存限制

250 MB

#include<bits/stdc++.h>
using namespace std;
#define N 1006
int vis[N], ans, n;
double k, l;
struct node{
double x, y, r;
}a[N];
double len(double x1, double y1, double x2, double y2){
return sqrt((x1-x2)*(x1-x2)+(y1-y2)*(y1-y2));
}
void init(){
memset(vis, 0, sizeof(vis));
memset(a, 0, sizeof(a));
ans = 0;
}
void dfs(int x){
if(a[x].y+a[x].r+k >= l){
ans = 1;
return;
}
vis[x] = 1;
for(int i=1;i<=n;i++){
if(vis[i]) continue;
if(len(a[x].x,a[x].y,a[i].x,a[i].y) <= a[x].r+a[i].r+k)
dfs(i);
}
}
int main(){
ios::sync_with_stdio(false);
cin.tie(0);
int t;
cin>>t;
while(t--){
init();
cin>>n>>l>>k;
for(int i=1;i<=n;i++)
cin>>a[i].x>>a[i].y>>a[i].r;
for(int i=1;i<=n;i++)
if(a[i].y <= k+a[i].r)
dfs(i);
if(ans) cout<<"Yes\n";
else cout<<"No\n";
}
return 0;
}

7-8 专8 括号匹配Plus 

在C语言中,我们会用到三种括号:圆括号 (),方括号 [] 和花括号 {} 。同学们想必都被编译时括号不匹配的提示折磨过,于是Azure学长为大家发明了一种万能括号,其中,万能左括号用 < 表示,而万能右括号用 > 表示。
万能括号可以与任意一个最近的一个未配对的相反方向括号进行配对,如在以下符号序列中:{[()>},最中间的圆括号正常配对,而方括号 [ 与万能括号 > 配对,最后两个花括号正常配对。

下面请你编写一个程序,用来判断所给字符串中的括号是否匹配

输入格式:

第一行输入一个数字n(1≤n≤100),表示n组数据。
接下来n行,每行输入一个字符串,判断其中出现的括号是否匹配。其中,每个字符串的长度不超过1000且不为空串。

输出格式:

对每一组输入,在一行内输出是否括号匹配。若匹配则输出YES,反之输出NO

输入样例:

在这里给出一组输入。例如:

3
int main()<printf("Hello, World!");}
{{scanf("%d",&n);}}}
int add(int a,int b){int c = a + b;return c;)

输出样例:

在这里给出相应的输出。例如:

YES
NO
NO

代码长度限制

16 KB

时间限制

400 ms

内存限制

64 MB

#include <iostream>
#include <stack>
using namespace std;
int main()
{
int n;
cin >> n;
getchar();
while (n--)
{
string str;
getline(cin, str);
stack<int> st;
bool flag = false;
for (int i = 0; str[i] != '\0'; i++)
{
if (str[i] == '(' || str[i] == '[' || str[i] == '{' ||
str[i] == '<')
{
st.push(str[i]);
}
else if (str[i] == '>' || str[i] == ')' || str[i] ==
']' || str[i] == '}')
{
if (st.empty())
{
printf("NO\n");
flag = true;
break;
}
if (str[i] == '>')
{
st.pop();
}
else if (str[i] == ')' && (st.top() == '(' ||
st.top() == '<'))
{
st.pop();
}
else if (str[i] == ']' && (st.top() == '[' ||
st.top() == '<'))
{
st.pop();
}
else if (str[i] == '}' && (st.top() == '{' ||
st.top() == '<'))
{
st.pop();
}
else
{
printf("NO\n");
flag = true;
break;
}
}
}
if (flag)
continue;
if (st.empty())
{
printf("YES\n");
}
else
{
printf("NO\n");
}
}
return 0;
}

这道题我做过类似的,和这个题解思路不一样,我们可以在栈中存入与左括号相反的右括号,遇到右括号再对比栈顶元素是不是一样,感觉更简单易懂。

7-9 专9 生成最少叶子树

给定一个具有 n 个顶点的树。顶点 1 为根。在一次操作中,你可以选择任何一个芽及其所有孩子,将它们重新悬挂到树的任何其他顶点上。通过执行此操作,你会删除连接芽和其父节点的边,并选择一个树上的顶点,在芽和所选的顶点之间添加一条边。所选的顶点不能是芽本身或其任何孩子。芽的所有孩子仍然与芽相连。

如果一个顶点没有孩子,则它是"叶子"。
如果一个顶点满足以下三个条件,我们称之为"芽":
(1) 不是根
(2) 至少有一个孩子
(3) 所有孩子都是叶子

在可以进行任意次上述操作的情况下(可能为零次),该树可能获得的叶子的最小数量是多少?

输入格式:

输入包含多个测试用例。第一行包含一个整数 t(1≤t≤104) —测试用例的数量。接下来是每个测试用例的描述。
每个测试用例的第一行包含一个整数 n(2≤n≤2×105) 给定树中顶点的数量。
接下来的 n−1 行每行包含两个整数 u 和 v(1≤u , v≤n , u=v),表示树中顶点 u 和 v 之间存在一条边。
保证给定的图是一棵树。
保证所有测试用例中 n 的总和不超过 2×105。

输出格式:

对于每个测试用例,输出一个整数 —— 经过一些操作后可能获得的叶子的最小数量。

输入样例:

在这里给出一组输入。例如:

3
7
1 2
1 3
1 4
2 5
2 6
4 7
2
1 2
7
7 3
1 5
1 3
4 6
4 7
2 1

输出样例:

在这里给出相应的输出。例如:

2
1
2

说明

在第一个测试用例中,树如下所示:
 

a8ab420b7ca4f310a11b4e815d2ee260498563d1.png


首先,你可以选择一个芽顶点 4 并将其悬挂到顶点 3。然后,你可以选择一个芽顶点 2 并将其悬挂到顶点 7。结果,你将得到以下具有 2 个叶子的树:
 

8b1cc9156e6793bcb9c75ddeca58490c5113c1cd.png


这是可能获得的最小叶子数。

代码长度限制

16 KB

时间限制

400 ms

内存限制

64 MB

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
#define fi first
#define se second
#define pb push_back
#define MP make_pair
const int inf = 1e9 + 10;
const int N = 2e5 + 10;
int n,ans;
vector<int> g[N];
int dfs(int u, int fa)
{
int sum = 0;
for(int i=0;i<g[u].size();i++)
{
int v = g[u][i];
if(v == fa) continue;
sum += dfs(v, u);
}
if(sum == 0) return 1;
else
{
ans += sum - 1;
return 0;
}
}
int main()
{
int t;
scanf("%d",&t);
while(t--)
{
ans = 1;
scanf("%d",&n);
for(int i=1;i<=n;i++) g[i].clear();
for(int i=1;i<n;i++)
{
int u,v;
scanf("%d%d",&u,&v);
g[u].pb(v);
g[v].pb(u);
}
dfs(1, 0);
printf("%d\n",ans);
}
return 0;
}

 7-10 专10 禁止超速

LZY大佬不想上学了,他打算自驾回家。从河北农业大学到LZY家有许多条道路,每条路上都有特定的限速,不幸的是,有些路上的限速标志丢失了,因此LZY不知道应该开多快,一种可行的方案是按照原先的速度行驶
LZY有一张城市交通路线地图,包含道路和路口的信息,每条道路是有向的,连接了两个路口A和B,A和B之间最多仅有一条道路,在道路起点处放置有一块限速标识(也可能丢失了)。身为一个老司机,LZY的行驶不受道路堵塞的影响,并且可以在瞬间完成加速和减速。当然,一定不能超过当前路段的限速。请你帮LZY大佬计算出他回家所需的最短时间是多少。

输入格式:

第一行是 3 个整数 N,M和 D,N表示路口的数目,用 1到N 标记。M 是道路的总数,D 表示LZY的目的地。
接下来的 M 行,每行描述一条道路,每行有 4 个整数 X (1≤X≤N),Y (1≤Y≤N),L (0≤L≤1000) 和 V(0≤V≤250),这条路是从 X 到 Y 的,长度为 L,速度限制是 V。如果 V 是 0,表示这条路的限速未知。
如果 V 不为 0,则经过该路的时间 T=VL​,否则 T=Vorg​L​​,Vorg​ 是你到达该路口前的速度。LZY从1出发,开始时的速度为 70

输出格式:

输出仅一个数,表示LZY从 1 到 D 所需要的最短时间,答案保留两位小数。

输入样例:

6 15 2
1 2 68 25
1 3 50 30
1 6 101 0
2 2 77 70
2 4 42 35
3 1 22 0
3 2 86 40
3 4 23 0
3 5 40 45
4 2 14 64
4 6 23 0
5 2 8 95
6 2 84 0
6 3 64 90
6 4 40 36

输出样例:

2.63

数据范围

对于 20% 的数据,V=0。
对于 100% 的数据,2≤N≤150,0≤L≤1000,1≤V≤250。

代码长度限制

16 KB

时间限制

400 ms

内存限制

64 MB

#include<bits/stdc++.h>
using namespace std;
#define N 155
#define V 255
int head[N], nex[N*N], to[N*N], speed[N*N], len[N*N], cnt = 0;
int vis[N][V]={0};
double d[N][V];
int n, m, t;
priority_queue< pair< double,pair<int,int> > >q;
void add(int x, int y, int l, int v){
nex[++cnt] = head[x];
head[x] = cnt;
to[cnt] = y;
speed[cnt] = v;
len[cnt] = l;
}
void dijkstra(){
for(int i=0;i<=n;i++){
for(int j=0;j<=250;j++){
d[i][j] = 0x3f3f3f3f;
}
}
d[1][70] = 0;
q.push(make_pair(0, make_pair(1, 70)));
while(q.size()){
int ov = q.top().second.second;
int u = q.top().second.first;
q.pop();
if(vis[u][ov])continue;
vis[u][ov] = 1;
for(int i=head[u];i;i=nex[i]){
int v = to[i], l = len[i], nv = speed[i];
if(nv == 0) nv = ov;
if(d[v][nv] > d[u][ov] + (double)l/(double)nv){
d[v][nv] = d[u][ov] + (double)l/(double)nv;
q.push(make_pair(-d[v][nv], make_pair(v, nv)));
}
}
}
}
int main(){
int x, y, v, l;
ios::sync_with_stdio(false);
cin.tie(0);
cin>>n>>m>>t;
for(int i=1;i<=m;i++){
cin>>x>>y>>l>>v;
add(x, y, l, v);
}
dijkstra();
int ansv = 0;
double minn = 0x3f3f3f3f;
for(int i=0;i<=250;i++){
if(d[t][i] < minn){
minn = d[t][i];
ansv = i;
}
}
printf("%.2lf", d[t][ansv]);
return 0;
}

 最后,再次希望能有感兴趣的朋友写一写java题解,我帮你提交评分,一起共同进步!

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

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

相关文章

麒麟系统添加环境变量

环境变量添加方法 方法一&#xff1a;用户主目录下的.profile或.bashrc文件&#xff08;推荐&#xff09; 登录到你的用户&#xff08;非root&#xff09;&#xff0c;在终端输入&#xff1a; sudo vim ~/.profile 或者 sudo vim ~/.bashrc 翻到该文件最后&#xff0c…

电容和电感

一、电感 1&#xff09;图片 2&#xff09;作用 a&#xff09;储存容量 例如dcdc转换器的原理,将一个电压值转换成另外一个电压值 b&#xff09;选择信号 比如空气中弥漫着很多信号&#xff0c;我们应该怎么选取我们所需要的信号。 电感和电容可以看成一个电阻&#xff0c;当电…

PTA结构体经典编程题

目录 第一题&#xff1a;计算平均成绩 第二题&#xff1a;平面向量加法 第三题&#xff1a;查找书籍 第四题&#xff1a;通讯录排序 第五题&#xff1a;计算职工工资 第一题&#xff1a;计算平均成绩 思路&#xff1a;看到一个学生的基本信息&#xff0c;所以定义一个结构…

神经网络模型预训练

根据神经网络各个层的计算逻辑用程序实现相关的计算&#xff0c;主要是&#xff1a;前向传播计算、反向传播计算、损失计算、精确度计算等&#xff0c;并提供保存超参数到文件中。 # coding: utf-8 import sys, os sys.path.append(os.pardir) # 为了导入父目录的文件而进行的…

【Python百练——第3练】矩形类及操作

&#x1f490;作者&#xff1a;insist-- &#x1f490;个人主页&#xff1a;insist-- 的个人主页 理想主义的花&#xff0c;最终会盛开在浪漫主义的土壤里&#xff0c;我们的热情永远不会熄灭&#xff0c;在现实平凡中&#xff0c;我们终将上岸&#xff0c;阳光万里 ❤️欢迎点…

Golang 原生Rpc Server实现

Golang 原生Rpc Server实现 引言源码解析服务端数据结构服务注册请求处理 客户端数据结构建立连接请求调用 延伸异步调用定制服务名采用TPC协议建立连接自定义编码格式自定义服务器 参考 引言 本文我们来看看golang原生rpc库的实现 , 首先来看一下golang rpc库的demo案例: 服…

python的制图

测试数据示例&#xff1a; day report_user_cnt report_user_cnt_2 label 2023-10-01 3 3 欺诈 2023-10-02 2 4 欺诈 2023-10-03 6 5 欺诈 2023-10-04 2 1 正常 2023-10-05 4 3 正常 2023-10-06 4 4 正常 2023-10-07 2 6 正常 2023-10-08 3 7 正常 2023-10-09 3 12 正常 2023-…

找不到DNS地址的解决方案

找不到DNS地址的解决方案 第一种解决方案&#xff1a;刷新DNS缓存第二种解决方案&#xff1a; 配置Internet协议版本4&#xff08;TCP/IPv4&#xff09;配置IP地址配置DNS地址 如何查看本机IPv4地址、子网掩码与默认网关 第一种解决方案&#xff1a;刷新DNS缓存 WINR输入cmd回…

基于SSH三大框架的员工管理系统

基于SSH三大框架的员工管理系统 摘要 本系统为本人学习SSH三大框架时所做的整合实例&#xff0c;系统角色包括普通用户和管理员两种&#xff0c;首页有管理员登录入口链接。系统功能主要包括管理员对用户的基本增、删、改、查和分页显示用户信息等。 系统环境 本系统使用ec…

【C++练级之路】【Lv.1】C++,启动!(命名空间,缺省参数,函数重载,引用,内联函数,auto,范围for,nullptr)

目录 引言入门须知一、命名空间1.1 作用域限定符1.2 命名空间的意义1.3 命名空间的定义1.4 命名空间的使用 二、C输入&输出2.1 cout输出2.2 cin输入2.3 std命名空间的使用惯例 三、缺省参数3.1 缺省参数概念3.2 缺省参数分类 四、函数重载4.1 函数重载概念4.2 函数重载分类…

BUUCTF 间谍启示录 1

BUUCTF:https://buuoj.cn/challenges 题目描述&#xff1a; 在城际公路的小道上&#xff0c;罪犯G正在被警方追赶。警官X眼看他正要逃脱&#xff0c;于是不得已开枪击中了罪犯G。罪犯G情急之下将一个物体抛到了前方湍急的河流中&#xff0c;便头一歪突然倒地。警官X接近一看&…

公平锁和非公平锁以及他们的实现原理是什么

文章目录 什么是非公平锁和公平锁呢&#xff1f;我们来看看acquire(1)的源码如下&#xff1a;这里的判断条件主要做两件事&#xff1a;在tryAcquire()方法中&#xff0c;主要是做了以下几件事&#xff1a;公平锁的tryAcquire()&#xff0c;实现的原理图如下&#xff1a;我们来看…

ORA-00257: archiver error. Connect internal only, until freed 的解决方法

归档文件存储空间不足&#xff0c;导致出现该问题。 当我们将数据库的模式修改为归档模式的时候&#xff0c;如果没有指定归档目录&#xff0c;默认的归档文件就会放到Flash Recovery Area的目录&#xff0c;但是这个目录是有大小限制的&#xff0c;如果超过了这个大小&#x…

C#基础学习--命名空间和程序集

引用其他程序集 编译器接受源代码文件并生成一个名为程序集的输出文件。 在许多项目中&#xff0c;会想使用来自其他程序集的类或类型。这些程序集可能来自BCL或第三方供应商&#xff0c;或者自己创建的。这些程序集称为类库&#xff0c;而且它们的程序集文件的名称通常以dll…

微信小程序组件与插件有啥区别?怎么用?

目录 一、微信小程序介绍 二、微信小程序组件 三、微信小程序插件 四、微信小程序组件与插件有啥区别 一、微信小程序介绍 微信小程序是一种基于微信平台的应用程序&#xff0c;它可以在微信客户端内直接运行&#xff0c;无需下载和安装。微信小程序具有轻量、便捷、跨平台…

对比ProtoBuf和JSON的序列化和反序列化能力

1.序列化能力对比验证 在这里让我们分别使用PB与JSON的序列化与反序列化能力&#xff0c;对值完全相同的一份结构化数据进行不同次数的性能测试。 为了可读性&#xff0c;下面这一份文本使用JSON格式展示了需要被进行测试的结构化数据内容: {"age" : 20,"name…

线程安全的问题以及解决方案

线程安全 线程安全的定义 线程安全:某个代码无论是在单线程上运行还是在多线程上运行,都不会产生bug. 线程不安全:单线程上运行正常,多线程上运行会产生bug. 观察线程不安全 看看下面的代码: public class ThreadTest1 {public static int count 0;public static void main…

数据结构和算法-树与二叉树的存储结构以及树和二叉树和森林的遍历

文章目录 二叉树的存储结构二叉树的顺序存储二叉树的链式存储小结 二叉树的先中后序遍历例题小结 二叉树的层次遍历小结 由遍历序列构造二叉树一个遍历序列即使给定了前中后序&#xff0c;也不能确定该二叉树的形态可以确定的序列组合前序中序后序中序层序中序 小结若前序&…

算力基础设施领域国家标准发布

2023 年 11 月 27 日&#xff0c;国家标准 GB/T 43331-2023《互联网数据中心&#xff08;IDC&#xff09;技术和分级要求》正式发布。这一国家标准由中国信息通信研究院&#xff08;简称“中国信通院”&#xff09;联合多家企事业单位编制&#xff0c;旨在满足当前国家算力基础…

强化学习(一)——基本概念及DQN

1 基本概念 智能体 agent &#xff0c;做动作的主体&#xff0c;&#xff08;大模型中的AI agent&#xff09; 环境 environment&#xff1a;与智能体交互的对象 状态 state &#xff1b;当前所处状态&#xff0c;如围棋棋局 动作 action&#xff1a;执行的动作&#xff0c;…