2022 年 CSP-J(中国计算机学会软件能力认证入门级)初赛真题与答案解析
一、单项选择题(共 15 题,每题 2 分,共计 30 分)
- 在内存储器中,每个存储单元都被赋予一个唯一的序号,称为( )。
A. 地址
B. 编号
C. 容量
D. 字节
答案:A
解析:内存储器中每个存储单元的唯一序号称为地址。 - 编译器的主要功能是( )。
A. 将源程序翻译成机器指令代码
B. 将源程序重新组合
C. 将低级语言翻译成高级语言
答案:A
解析:编译器的主要功能是将高级语言编写的源程序翻译成机器指令代码。 - 设**** x=true,y=true,z=false,以下逻辑运算表达式值为真的是( )。
A. (y∨z)∧x∧z
B. x∧(z∨y)∧z
C. (x∧y)∧z
答案:无正确选项(题目设计问题,所有选项结果均为假)
解析:根据逻辑运算规则,所有选项的计算结果均为假。 - 现有一张分辨率为 2048×1024 像素的 32 位真彩色图像,其存储容量为( )。
A. 16MB
B. 4MB
C. 8MB
D. 2MB
答案:C
解析:存储容量 = 分辨率 × 色深 / 8 = 2048×1024×32 / 8 = 8MB。 - 冒泡排序算法的伪代码如下,输入数组**** L,输出按非递减顺序排序的**** L。算法中 FLAG` ****的作用是( )。
FLAG ← n
while FLAG > 1 dok ← FLAG - 1FLAG ← 1for j = 1 to k doif L(j) > L(j+1) thenL(j) ↔ L(j+1)FLAG ← j
A. 标记被交换的最后元素位置
B. 记录循环次数
C. 优化算法效率
答案:A
解析:`FLAG 用于标记最后一次发生交换的位置,以减少不必要的比较。
- 设 ( A ) 是 ( n ) 个实数的数组,考虑下面的递归算法**** `XYZ(A[1…n]):
if n = 1 then return A[1]
else temp ← XYZ(A[1..n-1])
if temp < A[n] then return temp else return A[n]
算法**** `XYZ 的输出是什么?
A. ( A ) 数组的平均值
B. ( A ) 数组的最小值
C. ( A ) 数组的中值
答案:B
解析:算法通过递归比较返回数组中的最小值。
- 链表不具有的特点是( )。
A. 可随机访问任一元素
B. 不必事先估计存储空间
C. 插入删除不需要移动元素
答案:A
解析:链表需要通过指针遍历访问元素,无法随机访问。 - 有 10 个顶点的无向图至少应该有( )条边才能确保是一个连通图。
A. 8
B. 9
C. 10
答案:B
解析:( n ) 个顶点的无向连通图至少需要 ( n-1 ) 条边(树结构)。 - 二进制数 ( 1011 ) 转换成十进制数是( )。
A. 11
B. 10
C. 13
D. 12
答案:A
解析:( 1 \times 23 + 0 \times 22 + 1 \times 21 + 1 \times 20 = 8 + 0 + 2 + 1 = 11 )。 - 5 个小朋友并排站成一列,其中有两个小朋友是双胞胎,如果要求这两个双胞胎必须相邻,则有( )种不同排列方法?
A. 24
B. 48
C. 72
答案:B
解析:将双胞胎视为一个整体,与其他 3 个小朋友排列,共 ( 4! \times 2 = 48 ) 种方法。
二、阅读程序(程序输入不超过数组或字符串定义的范围;判断题正确填 √,错误填 ×;除特殊说明外,判断题 1.5 分,选择题 3 分,共计 40 分)
程序示例 1:
#include <iostream>
using namespace std;int main() {unsigned short x, y;cin >> x >> y;x = (x | x << 2) & 0x33;x = (x | x << 1) & 0x55;y = (y | y << 2) & 0x33;y = (y | y << 1) & 0x55;unsigned short z = x | y << 1;cout << z << endl;return 0;
}
判断题:
- 删去第 7 行与第 13 行的 unsigned,程序行为不变。(√)
解析:`short 类型在题目范围内不会溢出,符号位不影响结果。 - 将第 7 行与第 13 行的 short 均改为 char,程序行为不变。(×)
解析:`char 类型可能导致输入输出异常。
选择题:
3. 当输入为“13 8”时,输出为( )。
A. 0
B. 209
C. 197
D. 226
答案:D
解析:通过位运算计算,最终结果为 226。
三、完善程序(单选题,每小题 3 分,共计 30 分)
程序示例 2:递归求最小值
#include <iostream>
using namespace std;int XYZ(int A[], int n) {if (n == 1) return A[0];int temp = XYZ(A, n - 1);return (temp < A[n - 1]) ? temp : A[n - 1];
}int main() {int A[] = {5, 3, 8, 1, 9};int n = sizeof(A) / sizeof(A[0]);cout << XYZ(A, n) << endl;return 0;
}
单选题:
- 程序的功能是( )。
A. 求数组的平均值
B. 求数组的最小值
C. 求数组的最大值
答案:B
解析:递归比较返回最小值。