#2710. CSP-J 2021 第一轮(初赛)模拟II

CSP-J 2021 第一轮(初赛)模拟II

一、单项选择题(共 15 题,每题 2 分,共计 30 分;每题有且仅有一个正确选项)

第 1 题

以补码存储的 88 位有符号整数 1011011110110111 的十进制表示为 ( )。

{{ select(1) }}

  • 73-73
  • 183183
  • 7272
  • 72 -72

第 2 题

现有一段 2424 分钟的视频文件,它的帧率是 30Hz30Hz,分辨率是 1920×10801920×1080,每帧图像都是 3232 位真彩色图像,使用的视频编码算法达到了 2525% 的压缩率。则这个视频文件占用的存储空间大小约是 ( )。

{{ select(2) }}

  • 668GiB 668GiB
  • 334GiB334GiB
  • 85GiB85GiB
  • 500GiB500GiB

第 3 题

链接器的功能是 ( )。

{{ select(3) }}

  • 把源代码转换成特定硬件平台的机器指令把源代码转换成特定硬件平台的机器指令
  • 把机器指令组合成完整的可执行程序把机器指令组合成完整的可执行程序
  • 把源代码转换成可执行程序把源代码转换成可执行程序
  • 把高级语言翻译成低级语言把高级语言翻译成低级语言

第 4 题

对一个 nn 个顶点,mm 条边的带正权有向简单图使用 DijkstraDijkstra 算法计算单源最短路时,如果再使用一个可以在 Θ(loglog nn) 时间复杂度内查询堆内最小值、在 ΘΘ(n\sqrt{n}) 时间复杂度内合并两个堆、在 Θ(1)Θ(1) 时间复杂度内将堆内一个元素变小、在Θ Θ(loglog 𝑛𝑛) 时间复杂度内弹出堆内最小值的堆优化DijkstraDijkstra 算法,则整个 DijkstraDijkstra 算法的时间复杂度为 ( )。

{{ select(4) }}

  • Θ(𝑛n Θ(𝑛 \sqrt{n} + 𝑚𝑚 loglog 𝑛𝑛)
  • Θ((𝑛+𝑚) Θ((𝑛 + 𝑚) loglog 𝑛𝑛)
  • Θ(𝑚Θ(𝑚 + 𝑛𝑛 loglog 𝑛𝑛)
  • Θ(𝑚nΘ(𝑚\sqrt{n} + 𝑛𝑛 loglog 𝑛𝑛)

第 5 题

具有 nn 个顶点,mm 条边的连通图采用邻接矩阵存储结构,进行深度优先遍历运算的时间复杂度为 ( )。

{{ select(5) }}

  • Θ(𝑛3)Θ(𝑛^{3})
  • Θ(𝑛2)Θ(𝑛^{2})
  • Θ(𝑛+𝑚)Θ(𝑛 + 𝑚)
  • Θ(𝑚2) Θ(𝑚^{2})

第 6 题

下列算法中,没有运用分治思想的一项是 ( )。

{{ select(6) }}

  • 归并排序算法归并排序算法
  • 求二叉树的前序遍历求二叉树的前序遍历
  • 快速排序算法快速排序算法
  • 求二叉树的层次遍历求二叉树的层次遍历

第 7 题

前缀表达式 +ab+cd* + a b + c d 的中缀形式是 ( )。

{{ select(7) }}

  • (a+b)(c+d)(a + b) * (c + d)
  • a+bc+da + b * c + d
  • ab+cda * b + c * d
  • (d+c)(b+a) (d + c) * (b + a)

第 8 题

55 个从 1155 标号的小球和 55 个同样标号的盒子,现将小球随机放入盒子,每个盒子仅放 11 个小球,问每个盒子中的小球都与盒子标号不同的概率是 ( )。 {{ select(8) }}

  • 24625\frac{\mathrm{24}}{\mathrm{625}}
  • 720\frac{\mathrm{7}}{\mathrm{20}}
  • 43120\frac{\mathrm{43}}{\mathrm{120}}
  • 1130\frac{\mathrm{11}}{\mathrm{30}}

第 9 题 设 x=truex=true,y=falsey=false,z=truez=true。以下逻辑运算表达式值为 truetrue 的是( )。

{{ select(9) }}

  • (¬𝑥𝑦)𝑧 (¬𝑥 ∨ 𝑦) ∧ 𝑧
  • (𝑦𝑧)(𝑥𝑦) (𝑦 ∧ 𝑧) ∨ (𝑥 ∧ 𝑦)
  • (𝑥𝑦)𝑧 (𝑥 ∧ 𝑦) ∨ 𝑧
  • (𝑥𝑧)𝑦(𝑥 ∧ 𝑧) ∧ 𝑦

第 10 题

假设某算法的计算时间表示为递推关系式 𝑇𝑇(𝑛𝑛) = 3𝑇3𝑇 (n2\frac{\mathrm{n}}{\mathrm{2}}) + ΘΘ(𝑛𝑛),𝑇(1)𝑇(1) =Θ(1)Θ(1),则算法的时间复杂度为 ( )

{{ select(10) }}

  • Θ(nn)
  • Θ(nlog23n^{{log_2}^3})
  • Θ(nlognn log n)
  • Θ(nlog23lognn^{{log_2}^3}logn)

第 11 题

在一条长度为 11 的线段上随机取一个点,再在以原线段的左端点和取的该点为端点的线段上随机取一个点,则以取的两个点为端点的线段的期望长度是 ( )。

{{ select(11) }}

  • 1 / 2
  • 1 / 3
  • 1 / 4
  • 2 / 3

第 12 题

以下排序算法中最好情况下时间复杂度与最坏情况下时间复杂度相同的是( )。

{{ select(12) }}

  • 选择排序选择排序
  • 冒泡排序 冒泡排序
  • 插入排序 插入排序
  • 快速排序快速排序

第 13 题

44 个结点和 44 条边的有标号简单无向图的数量是 ( )。

{{ select(13) }}

  • 1515
  • 16 16
  • 66
  • 44

第 14 题

19461946 年,( )提出了存储程序原理,奠定了现代电子计算机基本结构,开创了程序设计的新时代。

{{ select(14) }}

  • 艾伦·麦席森·图灵(Alan Mathison Turing)。
  • 约翰·冯·诺依曼(John von Neumann)。
  • 克劳德·艾尔伍德·香农(Claude Elwood Shannon)。
  • 罗伯特·塔扬(Robert Tarjan)

第 15 题

在计算机非专业级别软件能力认证 CSPSCSP-S 进行时,下列行为中被允许的是 ( )。

{{ select(15) }}

  • 使用SSH协议远程登录其它计算机以获取试题等文件使用 SSH 协议远程登录其它计算机以获取试题等文件
  • 写程序在评测环境中修改输入文件写程序在评测环境中修改输入文件
  • 使用U盘拷贝题目及下发文件或自己的代码供赛后复盘使用 U 盘拷贝题目及下发文件或自己的代码供赛后复盘
  • 通过枚举输入文件的可能情况获得答案并写入源代码通过枚举输入文件的可能情况获得答案并写入源代码

二、阅读程序(程序输入不超过数组或字符串定义的范围;判断题正确选AA,错误选BB;除特殊说明外,判断题 2 分,选择题 3 分,共计 40 分)

1.

01 #include <cstdio>
02 #include <cstring>
03 
04 using namespace std;
05 
06 char s[10000];
07 int cnt[26];
08 
09 int main() {
10 scanf("%s", s);
11 for (int i = 0; i < strlen(s); ++i) {
12 if (cnt[s[i] - 'a'] <= 50) {
13 s[strlen(s)] = s[i];
14 }
15 ++cnt[s[i] - 'a'];
16 }
17 printf("%s\n", s);
18 return 0;
19 }

假设设初始时输入的字符串长度不超过 500500,且不是空串。完成下面的判 断题和单选题:

判断题

  1. 将程序第 1111 行中的++i”改为“i++“++i”改为“i++”,程序运行结果不会改变( ) {{ select(16) }}
  • 正确
  • 错误
  1. 将程序第 1111 行改为for“for(intint i=0i=0,len=strlen(s);i<len;++i)len=strlen(s);i<len;++i)”,程序的运行结果不会改变,同时程序的运行效率将得到提升( ) {{ select(17) }}
  • 正确
  • 错误
  1. 对于任意一个出现了 aazz 中所有的字符、且各字符出现的次数不小于5050 的字符串 bb,总存在一个字符串 aa,使得将字符串 aa 输入程序后的运 行结果为字符串 bb。( ) {{ select(18) }}
  • 正确
  • 错误
  1. 程序的输出字符串长度一定不小于 13001300(注:1300=50×261300=50×26)。( ) {{ select(19) }}
  • 正确
  • 错误

单选题

  1. 设输入字符串长度为 x1x500x(1≤x≤500),输出字符串长度为 yy,则关于 xxyy 的大小关系正确的是( )。

{{ select(20) }}

  • 对于全部的输入字符串,都有x=y对于全部的输入字符串,都有 x=y
  • 对于全部的输入字符串,都有x<y对于全部的输入字符串,都有 x<y
  • 存在一部分输入字符串,使得x=y;也存在一部分输入字符串,使得x<y;但是不存在x>y的情况存在一部分输入字符串,使得 x=y;也存在一部分输入字符串,使得x<y; 但是不存在x>y 的情况
  • $存在一部分输入字符串,使得 x=y;也存在一部分输入字符串,使得 x>y;还存在一部分输入字符串,使得 x<y$。
  1. (2 分)设字符串 wwabcd...zabcd...z,即从 aazzw w 中依次出现一次, 共 2626 个字符。若输入为 ww 重复出现两次的结果(即 abcdefg...zabcdefg...zabcdefg...zabcdefg...z,则输出结果为( )。 {{ select(21) }}
  • w重复出现50次的结果w 重复出现 50 次的结果
  • w重复出现51次的结果w 重复出现 51 次的结果
  • w重复出现52次的结果w 重复出现 52 次的结果
  • w重复出现53次的结果w 重复出现 53 次的结果

2.

01 #include <cstdio>
02 
03 const int N = 5010;
04 const int M = 20010;
05 const int inf = 1073741823;
06 
07 int e, bg[N], nx[M], to[M], wt[M];
08 inline void link(int u, int v, int w) {
09 to[++e] = v;
10 nx[e] = bg[u];
11 wt[e] = w;
12 bg[u] = e;
13 }
14 
15 int n, m, u, v, w;
16 int f[N], h[N << 1];
17 
18 void update(int x, int y) {
19 x += n - 1;
20 for (h[x] = y; x; x >>= 1)
21 h[x >> 1] = f[h[x]] < f[h[x^1]] ? h[x] : h[x^1];
22 }
23 
24 int main() {
25 scanf("%d%d", &n, &m);
26 for (int i = 0; i != m; ++i) {
27 scanf("%d%d%d", &u, &v, &w);
28 link(u, v, w);
29 }
30 int nn = n << 1;
31 for (int i = 1; i <= n; ++i) {
32 for (int j = 1; j != nn; ++j)
33 h[j] = 0;
34 for (int j = 0; j <= n; ++j)
35 f[j] = inf;
36 f[i] = 0;
37 update(i, i);
38 for (int j = i; true; j = h[1]) {
39 if (f[j] == inf) break;
40 for (int k = bg[j]; k; k = nx[k]) {
41 if (f[j] + wt[k] < f[to[k]]) {
42 f[to[k]] = f[j] + wt[k];
43 update(to[k], to[k]);
44 }
45 }
46 update(j, 0);
47 }
48 for (int j = 1; j <= n; ++j)
49 printf("%d%c", f[j], "\n "[j != n]);
50 }
51 return 0;
52 }

以下程序的输入是一张带边权的有向图,完成下面的判断题和单选题:

判断题

  1. 将程序中所有的 !=“!=” 替换为 <“<”,程序将仍然正常运行且输出的结果不会改变。 ( ) {{ select(22) }}
  • 正确
  • 错误
  1. 为了保证程序正常运行,输入的边数必须不大于 2×1042 × 104。 ( ) {{ select(23) }}
  • 正确
  • 错误
  1. 程序的输出是一个 n×nn×n 的整数矩阵。 ( ) {{ select(24) }}
  • 正确
  • 错误
  1. 将程序第 3434 行的 j=0“j=0” 替换为j=1 “j=1”,程序将仍然正常运行且输出的结果不会改变。 ( ) {{ select(25) }}
  • 正确
  • 错误

单选题

  1. (2 分)当输入的图中所有边的边权均为一个相同的正整数,且有𝑤𝑖<1073741823∑ 𝑤𝑖 < 1073741823 时,update“update” 函数被调用的次数为( )。 {{ select(26) }}
  • Θ(n2n^{2})。
  • Θ(𝑛𝑚𝑛𝑚)。
  • Θ(n2n^{2}+nmnm)。
  • Θ(𝑛𝑛 minmin(𝑛𝑛, 𝑚𝑚))。
  1. 当输入的边权均为正整数时,程序在最坏情况下的时间复杂度为( )。 {{ select(27) }}
  • Θ(n3n^{3})。
  • Θ(n2n^{2} loglog n+nm)。
  • Θ(𝑛𝑚 loglog 𝑛)。
  • Θ(n2n^{2}mm)。

3.

01 #include <bits/stdc++.h>
02 using namespace std;
03 
04 #define N 105
05 #define INF 1e9
06 
07 int dis1[N][N], dis2[N][N];
08 int mp[N][N], n, m;
09 
10 void fun1(int dis[N][N]) {
11 static bool vis[N];
12 for (int i = 1; i <= n; i++) {
13 for (int j = 1; j <= n; j++) {
14 dis[i][j] = mp[i][j];
15 }
16 }
17 for (int i = 1; i <= n; i++) {
18 for (int j = 1; j <= n; j++) vis[j] = 0;
19 for (int k = 1; k <= n; k++) {
20 int now = 0;
21 for (int j = 1; j <= n; j++) {
22 if (!vis[j] && (!now || dis[i][now] > dis[i][j]))
23 now = j;
24 }
25 vis[now] = 1;
26 for (int j = 1; j <= n; j++) {
27 if(!vis[j]&&dis[i][j] > dis[i][now]+mp[now][j]){
28 dis[i][j] = dis[i][now] + mp[now][j];
29 }
30 }
31 }
32 }
33 }
34 void fun2(int dis[N][N]) {
35 for (int i = 1; i <= n; i++) {
36 for (int j = 1; j <= n; j++) {
37 dis[i][j] = mp[i][j];
38 }
39 }
40 for (int i = 1; i <= n; i++) {
41 for (int j = 1; j <= n; j++) {
42 for (int k = 1; k <= n; k++) {
43 dis[i][j] = min(dis[i][j], dis[i][k] + dis[k][j]);
44 }
45 }
46 }
47 }
48 
49 int main() {
50 cin >> n >> m;
51 for (int i = 1; i <= n; i++) {
52 for (int j = 1; j <= n; j++) {
53 if (i == j) mp[i][j] = 0;
54 else mp[i][j] = INF;
55 }
56 }
57 for (int i = 1; i <= m; i++) {
58 int u, v, w;
59 cin >> u >> v >> w;
60 mp[u][v] = w;
61 }
62 fun1(dis1);
63 fun2(dis2);
64 int ans = 0;
65 for (int i = 1; i <= n; i++) {
66 for (int j = 1; j <= n; j++) {
67 if (dis1[i][j] != dis2[i][j])
68 ans++;
69 }
70 }
71 cout << ans << endl;
72 return 0;
73 }

以下程序的输入数据满足𝟏𝒏𝟏𝟎𝟎 𝟏 ≤ 𝒏 ≤ 𝟏𝟎𝟎, 𝟏𝒎𝟏 ≤ 𝒎n(n1)2\frac{\mathrm{n(n-1)}}{\mathrm{2}},且只保证不存在重边,即不存在 (uiu_i, viv_i) = (uju_j, vjv_j) (𝒊𝒋𝒊≠ 𝒋),边权 wiw_i ∈ [𝟏, 10610^{6}] 。如果u uv v 不可达,则认为距离为 INFINF 。完成下面的判断题和单选题

判断题

  1. 该代码的 dis1[i][j]dis1[i][j] 不一定是i ijj 的最短路。( ) {{ select(28) }}
  • 正确
  • 错误
  1. 输出可能为 11 。( ) {{ select(29) }}
  • 正确
  • 错误
  1. 将第 1919 行的 k<=nk <= n 修改为k<nk < n ,不影响答案。( ) {{ select(30) }}
  • 正确
  • 错误
  1. 对于稀疏图(n,mn,m 不同阶),fun1fun1() 对于单个 iidis[i][j]dis[i][j] (1𝑗𝑛1 ≤ 𝑗 ≤ 𝑛) ,最快可以做到 ΘΘ((𝑛𝑛 + 𝑚𝑚) loglog 𝑚𝑚) 。( ) {{ select(31) }}
  • 正确
  • 错误

单选题

  1. 对于以下的输入数据,输出结果为( )。
5 8
3 2 2
2 4 2
1 4 3
3 1 2
4 3 3
5 2 3
1 5 1
1 2 2

{{ select(32) }}

  • 22
  • 33
  • 44
  • 55
  1. 若输入数据 n=5“n=5” ,输出 ansans 的最大可能值为 ( )。 {{ select(33) }}
  • 44
  • 55
  • 66
  • 77

三、完善程序(单选题,每小题 3 分,共计 30 分)

  1. (装备穿戴问题)有n n 件装备,穿戴第 ii 件装备需要玩家的力量值至少为 aia_i,穿戴该装备后会让玩家的力量值增加 bib_i。现在请问玩家的初始力量值最小是多少,才能以某种顺序穿戴上所有的装备?

输入:第一行是一个整数 nn11𝑛𝑛10310^{3});第二行有 nn 个整数,第 ii 个整数表示aia_i00aia_i10910^{9});第三行有 n 个整数,第 i 个整数表示 bib_i(0 ≤ bib_i10610^{6})。

提示:使用二分+贪心的方法解决这个问题,先对装备按顺序进行排序,然后二分答案,并贪心地进行选择。

试补全程序。

01 #include <cstdio>
02 #include <algorithm>
03 
04 using namespace std;
05 const int maxn = 1005;
06 
07 int n;
08 int a[maxn], b[maxn], c[maxn];
09 
10 bool Comp(const int &x, const int &y) { 
11 // 你可以简单地认为括号内的内容等价于 (int x, int y)
12 return (1);
13 }
14 
15 bool check(int x) {
16 for (int i = 1; i <= n; ++i) {
17 int u = c[i];
18 if ((2)) {
19 x += b[u];
20 } else {
21 return false;
22 }
23 }
24 return true;
25 }
26 
27 int main() {
28 scanf("%d", &n);
29 for (int i = 1; i <= n; ++i) scanf("%d", a + i);
30 for (int i = 1; i <= n; ++i) scanf("%d", b + i);
31 for (int i = 1; i <= n; ++i) c[i] = i;
32 sort(c + 1, c + 1 + n, Comp);
33 int ans = 1145141919;
34 for (int l=1, r=ans, mid=(l+r)/2; (3); mid=(l+r)/2)
35 if (check(mid)) {
36 ans = mid;
37 (4);
38 } else {
39 (5);
40 }
41 printf("%d\n", ans);
42 return 0;
43 }
  1. (1) 处应填( )。 {{ select(34) }}
  • a[x]>a[y]a[x] > a[y]
  • a[x]<a[y]a[x] < a[y]
  • a[x]>=a[y]a[x] >= a[y]
  • a[x]<=a[y]a[x] <= a[y]
  1. (2) 处应填( )。 {{ select(35) }}
  • x<a[i]x < a[i]
  • x<a[u]x < a[u]
  • x>=a[i] x >= a[i]
  • x>=a[u]x >= a[u]
  1. (3)处应填( )。 {{ select(36) }}
  • l<rl < r
  • l<=rl <= r
  • check(l)check(l)
  • check(r) check(r)
  1. (4) 处应填( )。 {{ select(37) }}
  • r=mid1r = mid – 1
  • r=mid+1r = mid + 1
  • l=mid1 l = mid – 1
  • l=mid+1 l = mid + 1
  1. (5) 处应填( )。 {{ select(38) }}
  • r=mid1r = mid – 1
  • r=mid+1r = mid + 1
  • l=mid1l = mid – 1
  • l=mid+1l = mid + 1
  1. (打音游)小 AA 最近喜欢上了一款音游,并希望在结算时得到特定分数,例如 19198101919810 分。这款音游的得分计算方式如下:一共有n n 个音符,将一千万(10710^{7} )分平分给所有音符得到基础得分𝑥 𝑥 = 10710^{7}/n(保留非整数部分),其中有 mm 个音符根据是否击中可以获得 x+1x+1 分或者00 分,剩下的nmn-m 个音符根据击中精度可以获得 x+1x+1xxx/2x/200 分中的一个,最后将总得分向下取整即可得到最终得分。

给定 nn,mm,小A A 想知道他可以得到多少种不同的分数。

输入为两个非负整数,分别表示 nn,mm;满足11𝑛 𝑛10710^{7}00𝑚𝑚𝑛𝑛。输出为一个正整数表示答案。

试补全程序。

01 #include<iostream>
02 using namespace std;
03 int main()
04 {
05 int n,m;
06 cin>>n>>m;
07 if(m==n) {
08 cout<<(1)<<endl;
09 return 0;
10 }
11 long long M=10000000;
12 int ans=(2);
13 int lst=0;
14 for(int i=1;i<=n;++i) {
15 for(int j=1;j>=0;--j) {
 16 int lower=max(0,(3));
17 int upper=i-j;
18 int base=(4);
19 ans+=upper-lower+1;
20 if(lower+base<=lst) ans-=lst-(lower+base)+1;
21 lst=(5);
22 }
23 }
24 cout<<ans<<endl;
25 return 0;
26 }
  1. (1) 处应填( )。 {{ select(39) }}
  • 1 -1
  • n1n-1
  • n n
  • n+1 n+1
  1. (2) 处应填( )。 {{ select(40) }}
  • 1-1
  • 00
  • 1 1
  • nn
  1. (3)处应填( )。 {{ select(41) }}
  • i(nm)1i – (n - m) – 1
  • i(nm)ji – (n - m) - j
  • i(nm)i – (n - m)
  • i(nm)+1i – (n - m) + 1
  1. (4) 处应填( )。 {{ select(42) }}
  • (2i+j)M/(2n)(2*i+j) * M / (2*n)
  • (2ij)M/(2n)(2*i-j) * M / (2*n)
  • iM/n+jM/(2n)i * M / n + j * M / (2*n)
  • iM/njM/(2n)i * M / n - j * M / (2*n)
  1. (5) 处应填( )。 {{ select(43) }}
  • base+upperbase + upper
  • base+upper+1 base + upper + 1
  • base+lower base + lower
  • base+lower+1base + lower + 1