选 单项选择题(共 15 题,共 0 分)
一个32位无符号整数可以表示的最大值,最接近下列哪个选项?( )
在 C++ 中,执行int x = 255; cout<<(x&(x-1));后,输出的结果是?()
函数calc(n)的定义如下,则calc(5)的返回值是多少?()
int calc(int n) {
if (n <= 1) return 1;
if (n % 2 == 0) return calc(n / 2) + 1;
else return calc(n - 1) + calc(n - 2);
}
用 $5$ 个权值 $10,12,15,20,25$ 构造哈夫曼树,该树的带权路径长度是多少?( )
在一个有向图中,所有顶点的入度之和等于所有顶点的出度之和,这个总和等于?()
从 $5$ 位男生和 $4$ 位女生中选出 $4$ 人组成一个学习小组,要求学习小组中男生和女生都有。有多少种不同的选举方法?()
假设 a,b,c都是布尔变量,逻辑表达式 (a &&b)||(!c &&a) 的值与下列哪个表达式不始终相等?()
假设 a、b、c 都是布尔变量,逻辑表达式(a && b) || (!c && a) 的值与下列哪个表达式不始终相等?()
已知 $f[0]=1$、$f[1]=1$,并且对于所有$n \geq 2$ 有$f[n]=(f[n-1]+f[n-2])%7$,那么$f[2025]$的值是多少?()
下列关于 C++ string 类的说法,正确的是?()
考虑以下 C++ 函数:
void solve(int &a, int b) {
a = a + b;
b = a - b;
a = a - b;
}
int main() {
int x = 5, y = 10;
solve(x, y);
}
在 main 函数调用 solve 后,x 和 y 的值分别是?()
一个 $8\times 8$ 的棋盘,左上角坐标为 $(1,1)$,右下角为 $(8,8)$。一个机器人从 $(1,1)$ 出发,每次只能向右或向下走一格。要到达 $(4,5)$,有多少种不同的路径?()
某同学用冒泡排序对数组 ${6,1,5,2,4}$ 进行升序排序,请问需要进行多少次元素交换 ? ( )
十进制数 $720_{10}$ 和八进制数 $270_8$ 的和用十六进制表示是多少?()
一棵包含 $1000$ 个结点的完全二叉树,其叶子结点的数量是多少?()
给定一个初始为空的整数栈 $S$ 和一个空的队列 $P$。我们按顺序处理输入的整数队列 $A$: 7,5,8,3,1,4,2 。对于队列 $A$ 中的每一个数,执行以下规则:如果该数是奇数,则将其压入栈 $S$;如果该数是偶数,且栈 $S$ 非空,则弹出一个栈顶元素,并加入到队列 $P$ 的末尾:如果该数是偶数,且栈 $S$ 为空,则不进行任何操作。当队列 $A$ 中的所有数都处理完毕后,队列 $P$ 的内容是什么?()
阅 阅读程序(共 18 题,共 0 分)
#include <algorithm>
#include <cstdio>
#include <cstring>
inline int gcd(int a, int b) {
if (b == 0)
return a;
return gcd(b, a % b);
}
int main() {
int n;
scanf("%d", &n);
int ans = 0;
for (int i = 1; i <= n; ++i) {
for (int j = i + 1; j <= n; ++j) {
for (int k = j + 1; k <= n; ++k) {
if (gcd(i, j) == 1 && gcd(j, k) == 1
&& gcd(i, k) == 1) {
++ans;
}
}
}
}
printf("%d\n", ans);
return 0;
}
当输入为 2 时,程序并不会执行第 16 行的判断语句。()
将第 16 行中的 && gcd(i, k) == 1 删去不会影响程序运行结果。( )
当输入的 $n\geq 3$ 的时候,程序总是输出一个正整数。()
将第 7 行的 gcd(b, a % b) 改为gcd(a, a % b) 后,程序可能出现的问题是()。
当输入为 8 的时候,输出为( )。
调用 gcd(36, 42) 会返回 ( )。
#include <algorithm>
#include <cstdio>
#include <cstring>
#define ll long long
int n, k;
int a[200007];
int ans[200007];
int main() {
scanf("%d%d", &n, &k);
for (int i = 1; i <= n; ++i) {
scanf("%d", &a[i]);
}
std::sort(a + 1, a + n + 1);
n = std::unique(a + 1, a + n + 1) - a - 1;
for (int i = 1, j = 0; i <= n; ++i) {
for (; j < i && a[i] - a[j + 1] > k; ++j)
;
ans[i] = ans[j] + 1;
}
printf("%d\n", ans[n]);
return 0;
}
当输入为 3 1 3 2 1 时,输出结果为 2。()
假设输入的 n 为正整数,输出的答案一定小于等于n,大于等于 1。()
将第 14 行的 n = std::unique(a + 1, a + n + 1) - a - 1; 删去后,有可能出现与原本代码不同的输出结果。()
假设输入的 a 数组和 k 均为正整数,执行第 18 行代码时,一定满足的条件不包括()。
当输入的 $n=100$、$k=2$、$a={1,2,…,100}$ 时,输出为()
假设输入的 a 数组和 k 均为正整数,但 a 数组不一定有序,则若误删去第 13 行的 std::sort(a+1,a+n+1);,程序有可能出现的问题有()。
#include <algorithm>
#include <cstdio>
#include <cstring>
#define ll long long
int f[5007][5007];
int a[5007], b[5007];
int n;
int main() {
scanf("%d", &n);
for (int i = 1; i <= n; ++i) {
scanf("%d", &a[i]);
}
for (int i = 1; i <= n; ++i) {
scanf("%d", &b[i]);
}
for (int i = 1; i <= n; ++i) {
for (int j = 1; j <= n; ++j) {
f[i][j] = std::max(f[i][j], std::max(f[i - 1][j], f[i][j - 1]));
if (a[i] == b[j]) {
f[i][j] = std::max(f[i][j], f[i - 1][j - 1] + 1);
}
}
}
printf("%d\n", f[n][n]);
return 0;
}
当输入 4 1 2 3 4 1 3 2 2 时 ,输出为 2 。 ( )
当程序运行完毕后,对于所有的 $1\leq i$,$j\leq n$,都一定有 f[i][j] <= f[n][n]。()
将第 18 行的 f[i][j] = std::max(f[i][j], std::max(f[i - 1][j], f[i][j - 1]); 删去后,并不影响程序运行结果。()
输出的答案满足的性质有( )。
如果在 16 行的循环前加上以下两行: std::sort(a + 1, a + n + 1); std::sort(b + 1, b + n + 1), 则答案会 ( ) 。
如果输入的 a={1, 2, … , n}, 而且 b 数组中数字均为 1~n 中的正整数,则上述代码等价于下面哪个问题:( )。
完 完善程序(共 10 题,共 0 分)
#include <cctype>
#include <iostream>
#include <string>
using namespace std;
int main() {
string z;
cin >> z;
string s = "";
for (int i = 0; i < z.length(); ) {
char ch = z[i];
if (_____①_____ && isdigit(z[i + 1])) {
i++;
int count = 0;
while (i < z.length() && isdigit(z[i])) {
count = _____②_____;
i++;
}
for (int j = 0; j < _____③_____; ++j) {
s += ch;
}
} else {
s += _____④_____;
_____⑤_____;
}
}
cout << s << endl;
return 0;
}
①处应填 ( )
②处应填( )
③处应填()
④处应填()
⑤处应填()
#include <iostream>
#include <vector>
using namespace std;
int N;
bool query(int i, int j);
int main() {
cin >> N;
int candidate = 0;
int count = _____①_____;
for (int i = 1; i < N; ++i) {
if (_____②_____) {
candidate = i;
count = 1;
} else {
if (_____③_____) {
_____④_____;
} else {
count++;
}
}
}
cout << _____⑤_____ << endl;
return 0;
}
①处应填()
②处应填()
③处应填()
④处应填()
⑤处应填()