#10122. CSP-J2026 初赛模拟卷05
一、单项选择题(共15题,每题2分,共计30分;每题有且仅有一个正确选项)
- 阅读下面代码,输出结果是?
int a = 7, b = 3;
cout << a / b * b + a % b;
{{ select(1) }}
- 6
- 7
- 8
- 10
- 十六进制数 与二进制数 的和对应的十进制值是?
{{ select(2) }}
- 83
- 84
- 85
- 86
- 阅读下面代码,输出结果是?
int x = 0, y = 1;
if (x && ++y) {
y += 10;
}
cout << y;
{{ select(3) }}
- 0
- 1
- 2
- 11
- 阅读下面代码,输出结果是?
string s = "algorithm";
cout << s.substr(2, 4);
{{ select(4) }}
- gori
- gorit
- lgo
- orit
- 如果一棵二叉树高度为 ,根结点高度为 1,则高度至少为多少时,二叉树最多可以包含不少于 2026 个结点?
{{ select(5) }}
- 9
- 10
- 11
- 12
- 一个不含重边和自环的无向图有 5 个顶点,若用邻接矩阵表示,矩阵中最多可能有多少个非零元素?
{{ select(6) }}
- 10
- 15
- 20
- 25
- 有向无环图中有边 。该图共有多少种不同的拓扑排序?
{{ select(7) }}
- 3
- 6
- 12
- 24
- 下列关于队列的说法,正确的是?
{{ select(8) }}
- 队列是后进先出的数据结构
- 队列只能使用链表实现
- 队列常用于广度优先搜索
- 队列中的元素必须按大小有序
- 有 5 本不同的书排成一排,其中指定的两本书不能相邻,共有多少种排列方式?
{{ select(9) }}
- 48
- 60
- 72
- 96
- 递归函数定义如下:
f(1)=1
f(n)=2*f(n-1)+1 (n>=2)
{{ select(10) }}
- 15
- 31
- 32
- 63
- C++ 中
priority_queue<int>默认情况下,队首元素是?
{{ select(11) }}
- 最早加入的元素
- 最晚加入的元素
- 当前最小的元素
- 当前最大的元素
- 下面代码片段的时间复杂度是?
for (int i = 1; i <= n; i++)
for (int j = 1; j <= i; j *= 2)
cout << i + j << endl;
{{ select(12) }}
- 对含有 4096 个元素的有序数组进行二分查找,最坏情况下最多需要比较多少次?
{{ select(13) }}
- 11
- 12
- 13
- 14
- 有 5 个字符,其出现频率分别为 。若使用哈夫曼编码,则频率为 3 的字符编码长度为?
{{ select(14) }}
- 1
- 2
- 3
- 4
- 在 C++ 表达式中,下列运算符通常优先级最高的是?
{{ select(15) }}
=&&+*
二、阅读程序(程序输入不超过数组或字符串定义的范围;判断题正确填 √,错误填 ×;除特殊说明外,判断题每题 1.5 分,选择题每题 3 分,共计 40 分)
阅读程序(一)
#include <iostream>
#include <string>
using namespace std;
string cal(string s) {
string t;
for (int i = 0; i < s.size(); i++) {
if (!t.empty() && t.back() == s[i])
t.pop_back();
else
t += s[i];
}
if (t.empty())
return "EMPTY";
return t;
}
int main() {
string s;
cin >> s;
cout << cal(s) << endl;
return 0;
}
假设输入字符串非空,只包含小写字母。
判断题
- 当输入为
abba时,程序输出为EMPTY。
{{ select(16) }}
- 正确
- 错误
- 当输入为
aabbcc时,程序输出为EMPTY。
{{ select(17) }}
- 正确
- 错误
- 若输入字符串长度为奇数,程序不可能输出
EMPTY。
{{ select(18) }}
- 正确
- 错误
单项选择题
- 当输入为
abbaca时,程序输出为?
{{ select(19) }}
- EMPTY
- ca
- ba
- aca
- 设输入字符串长度为 ,该程序的时间复杂度为?
{{ select(20) }}
阅读程序(二)
#include <iostream>
using namespace std;
int c[15], dp[105];
int main() {
int n, m;
cin >> n >> m;
for (int i = 1; i <= n; i++)
cin >> c[i];
dp[0] = 1;
for (int i = 1; i <= n; i++) {
for (int j = c[i]; j <= m; j++) {
dp[j] += dp[j - c[i]];
}
}
cout << dp[m] << endl;
return 0;
}
假设 ,,且所有 均为正整数。
判断题
- 程序执行过程中, 的值始终为 1。
{{ select(21) }}
- 正确
- 错误
- 程序统计的是使用若干个数凑出 的有序方案数。
{{ select(22) }}
- 正确
- 错误
- 若将第二层循环改为从 到 递减枚举,则每个 最多只能使用一次。
{{ select(23) }}
- 正确
- 错误
单项选择题
- 若输入为:
3 5
1 2 5
{{ select(24) }}
- 3
- 4
- 5
- 6
- 若输入为:
2 6
2 3
{{ select(25) }}
- 1
- 2
- 3
- 4
- 该程序的时间复杂度为?
{{ select(26) }}
阅读程序(三)
#include <iostream>
using namespace std;
int fa[105], dep[105];
int lca(int x, int y) {
while (dep[x] > dep[y])
x = fa[x];
while (dep[y] > dep[x])
y = fa[y];
while (x != y) {
x = fa[x];
y = fa[y];
}
return x;
}
int main() {
int n, x, y;
cin >> n;
fa[1] = 0;
dep[1] = 1;
for (int i = 2; i <= n; i++) {
cin >> fa[i];
dep[i] = dep[fa[i]] + 1;
}
cin >> x >> y;
int z = lca(x, y);
cout << z << " " << dep[x] + dep[y] - 2 * dep[z] << endl;
return 0;
}
假设输入表示一棵以 1 为根的有根树,且对任意 ,都有 。
判断题
- 若输入的 和 相等,则程序输出的第二个数一定为
0。
{{ select(27) }}
- 正确
- 错误
- 程序输出的第二个数表示 到 的简单路径上经过的边数。
{{ select(28) }}
- 正确
- 错误
- 若将
dep[1] = 1改为dep[1] = 0,程序输出的第二个数一定不变。
{{ select(29) }}
- 正确
- 错误
单项选择题
- 若输入为:
7
1 1 2 2 3 3
4 5
{{ select(30) }}
1 22 22 34 0
- 若输入为:
7
1 1 2 2 3 3
4 6
{{ select(31) }}
1 42 33 34 6
- 若输入为:
9
1 1 2 2 4 4 5 5
6 9
{{ select(32) }}
1 52 44 45 3
三、完善程序(单选题,每题 3 分,共计 30 分)
完善程序(一)
下面程序计算 ,其中 为非负整数, 为正整数。请补全程序。
#include <iostream>
using namespace std;
using ll = long long;
ll pw(ll a, ll b, ll p) {
ll r = 1 % p;
a %= p;
while (b > 0) {
if (①)
r = ②;
a = ③;
b = ④;
}
return ⑤;
}
int main() {
ll a, b, p;
cin >> a >> b >> p;
cout << pw(a, b, p) << endl;
return 0;
}
- ① 处应填?
{{ select(33) }}
b == 0b % 2 == 1a % 2 == 1p % 2 == 1
- ② 处应填?
{{ select(34) }}
r + ar * a % pa * a % pb * a % p
- ③ 处应填?
{{ select(35) }}
a + aa * b % pa * a % pr * r % p
- ④ 处应填?
{{ select(36) }}
b - 1b + 1b * 2b / 2
- ⑤ 处应填?
{{ select(37) }}
abpr
完善程序(二)
下面程序使用 Floyd 算法求无向带权图中两点之间的最短距离。若两点不连通,输出 -1。请补全程序。
#include <iostream>
using namespace std;
const int INF = 1000000000;
int d[105][105];
int main() {
int n, m;
cin >> n >> m;
for (int i = 1; i <= n; i++) {
for (int j = 1; j <= n; j++) {
d[i][j] = ①;
}
}
for (int i = 1; i <= m; i++) {
int u, v, w;
cin >> u >> v >> w;
if (②)
d[u][v] = d[v][u] = w;
}
for (int k = 1; k <= n; k++) {
for (int i = 1; i <= n; i++) {
for (int j = 1; j <= n; j++) {
if (③)
d[i][j] = ④;
}
}
}
int s, t;
cin >> s >> t;
if (⑤)
cout << -1 << endl;
else
cout << d[s][t] << endl;
return 0;
}
- ① 处应填?
{{ select(38) }}
i == j ? 0 : INFi == j ? INF : 00INF
- ② 处应填?
{{ select(39) }}
w > d[u][v]w < d[u][v]u == vd[u][v] == 0
- ③ 处应填?
{{ select(40) }}
d[i][j] < d[i][k] + d[k][j]d[i][k] + d[k][j] < d[i][j]d[i][k] < d[k][j]d[i][j] == INF
- ④ 处应填?
{{ select(41) }}
d[i][j]d[i][k]d[k][j]d[i][k] + d[k][j]
- ⑤ 处应填?
{{ select(42) }}
d[s][t] == 0d[s][t] == INFs == td[s][t] < INF