#C1220. CSP 2025 入门级第一轮
CSP 2025 入门级第一轮
一、单项选择题
(共 15 题,每题 2 分,共计 30 分;每题有且仅有一个正确选项)
【第 1 题】
一个 位无符号整数可以表示的最大值,最接近下列哪个选项?( )。
{{ select(1) }}
【第 2 题】
在 C++ 中,执行 int x = 255; cout << (x & (x - 1)); 后,输出的结果是?( )
{{ select(2) }}
- 255
- 254
- 128
- 0
【第 3 题】
函数 的定义如下,则 的返回值是多少?( )

{{ select(3) }}
- 5
- 6
- 7
- 8
【第 4 题】
用 5 个权值 构造哈夫曼树,该树的带权路径长度是多少?( )
{{ select(4) }}
- 176
- 186
- 196
- 206
【第 5 题】
在一个有向图中,所有顶点的入度之和等于所有顶点的出度之和,这个总和等于?( )
{{ select(5) }}
- 顶点数
- 边数
- 顶点数 + 边数
- 顶点数 * 2
【第 6 题】
从 5 位男生和 4 位女生中选出 4 人组成一个学习小组,要求学习小组中男生和女生都有。有多少种不同的选举方法?( )
{{ select(6) }}
- 126
- 121
- 120
- 100
【第 7 题】
假设 都是布尔变量,逻辑表达式 (a && b) || (!c && a) 的值与下列哪个表达式不始终相等?( )
{{ select(7) }}
a && (b || !c)(a || !c) && (b || !c) && (a || a)a && (!b || c)!(!a || !b) || (a && !c)
【第 8 题】
已知 ,并且对于所有 有 。
那么 的值是多少?( )
{{ select(8) }}
- 2
- 4
- 5
- 6
【第 9 题】
下列关于 C++ string 类的说法,正确的是?( )
{{ select(9) }}
- string 对象的长度在创建后不能改变。
- 可以使用
+运算符直接连接一个 string 对象和一个 char 类型的字符。 - string 的
length()和size()方法返回的值可能不同。 - string 对象必须以
'\0'结尾,且这个结尾符计入length()。
【第 10 题】
考虑以下 C++ 函数:

在 main 函数调用 solve 后, 和 的值分别是?( )
{{ select(10) }}
- 5, 10
- 10, 5
- 10, 10
- 5, 5
【第 11 题】
一个 的棋盘,左上角坐标为 ,右下角为 。一个机器人从 出发,每次只能向右或向下走一格。要到达 ,有多少种不同的路径?( )
{{ select(11) }}
- 20
- 35
- 56
- 70
【第 12 题】
某同学用冒泡排序对数组 进行升序排序,请问需要进行多少次元素交换?( )
{{ select(12) }}
- 5
- 6
- 7
- 8
【第 13 题】
十进制数 和八进制数 的和用十六进制表示是多少?( )
{{ select(13) }}
-
-
-
-
【第 14 题】
一棵包含 个结点的完全二叉树,其叶子结点的数量是多少?( )
{{ select(14) }}
- 499
- 512
- 500
- 501
【第 15 题】
给定一个初始为空的整数栈 和一个空的队列 。我们按顺序处理输入的整数队列 :。对于队列 中的每一个数,执行以下规则:如果该数是奇数,则将其压入栈 ;如果该数是偶数,且栈 非空,则弹出一个栈顶元素,并加入到队列 的末尾;如果该数是偶数,且栈 为空,则不进行任何操作。当队列 中的所有数都处理完毕后,队列 的内容是什么?( )
{{ select(15) }}
- 5, 1, 3
- 7, 5, 3
- 3, 1, 5
- 5, 1, 3, 7
二、阅读程序
(程序输入不超过数组或字符串定义的范围;判断题正确填 √,错误填 ⨉ ;除特殊说明外,判断题 1.5 分,选择题 3 分,共计 40 分)
阅读程序(一)

判断题
- 当输入为 时,程序并不会执行第 行的判断语句。 {{ select(16) }}
- 正确
- 错误
-
将第 行中的 “&& gcd(i,k)==1” 删去不会影响程序运行结果。
{{ select(17) }}
- 正确
- 错误
-
当输入的 的时候,程序总是输出一个正整数。
{{ select(18) }}
- 正确
- 错误
单选题
-
将第 行的 “gcd(b,a%b)” 改为 “gcd(a,a%b)” 后,程序可能出现的问题是( )。
{{ select(19) }}
- 输出的答案大于原答案。
- 输出的答案小于原答案。
- 程序有可能陷入死循环。
- 可能发生整型溢出问题。
- 当输入为 的时候,输出为( )。 {{ select(20) }}
- 37
- 42
- 35
- 25
-
调用 会返回( )。
{{ select(21) }}
- 6
- 252
- 3
- 2
阅读程序(二)

判断题
-
当输入为 “” 时,输出结果为 。
{{ select(22) }}
- 正确
- 错误
-
假设输入的 为正整数,输出的答案一定小于等于 ,大于等于 。
{{ select(23) }}
- 正确
- 错误
- 将第 行“” 删去后,有可能出现与原本代码不同的输出结果。
{{ select(24) }}
- 正确
- 错误
单选题
- 假设输入的 数组和 均为正整数,执行第 行代码时,一定满足的条件不包括( )。 {{ select(25) }}
-
当输入的 时,输出为( )。
{{ select(26) }}
- 34
- 100
- 50
- 33
- 假设输入的 数组和 均为正整数,但 数组不一定有序,则若误删去第 行的“
std::sort(a+1,a+n+1);”,程序有可能出现的问题有( )。
{{ select(27) }}
- 输出的答案比原本答案更大
- 输出的答案比原本答案更小
- 出现死循环行为
- 以上均可能发生
阅读程序(三)


判断题
- 当输入 “” 时,输出为 。 {{ select(28) }}
- 正确
- 错误
- 当程序运行完毕后,对于所有的 ,都一定有 。 {{ select(29) }}
- 正确
- 错误
- 将第 行的 “” 删去后,并不影响程序运行结果。
{{ select(30) }}
- 正确
- 错误
单选题
-
输出的答案满足的性质有( )。
{{ select(31) }}
- 小于等于
- 大于等于
- 不一定大于等于
- 以上均是
- 如果在 行的循环前加上以下两行:“
std::sort(a+1,a+n+1);
std::sort(b+1,b+n+1)”,则答案会( )。
{{ select(32) }}
- 变大或不变
- 变小或不变
- 一定变大
- 不变
-
如果输入的 ,而且 数组中数字均为 中的正整数,则上述代码等价于下面哪个问题:( )。
{{ select(33) }}
- 求 数组去重后的长度
- 求 数组的最长上升子序列
- 求 数组的长度
- 求 数组的最大值
三、程序填空
(单选题,每小题 3 分,共计 30 分)
程序填空(一)
(字符串解码)“行程长度编码”(Run-Length Encoding)是一种无损压缩算法,常
用于压缩重复字符较多的数据,以减少存储空间。假设原始字符串不包含数字字符。压缩规则
如下:i)如果原始字符串中一个字符连续出现 次(),在压缩字符串中它被表示为 “字符+数字 ”。例如,编码 “” 代表 个连续的字符 。ii)如果原始字符串中一个字符只出现 次,在压缩字符串中它就表示为该字符本身。例如,编码 “” 代表 个字符 。
以下程序实现读取压缩字符串并输出其原始的、解压后的形式。试补全程序。

- ① 处应填( )。 {{ select(34) }}
- ② 处应填( )。 {{ select(35) }}
- ③ 处应填( )。 {{ select(36) }}
- ④ 处应填( )。 {{ select(37) }}
- ⑤ 处应填( )。 {{ select(38) }}
// 不执行任何操作
完善程序(二)
(精明与糊涂)有 个人,分为两类:i)精明人:永远能正确判断其他人是精明还是糊涂;
ii)糊涂人:判断不可靠,会给出随机的判断。已知精明人严格占据多数,即如果精明人有 个,则满足 。
你只能通过函数 让第 个人判断第 个人:返回 表示判断结果为 “精明人”;返回 表示判断结果为 “糊涂人”。你的目标是,通过这些互相判断,找出至少一个百分之百能确定的精明人。同时,你无需关心 的内部实现。
以下程序利用 “精明人占多数” 的优势。设想一个 “消除” 的过程,让人们互相判断并进行抵消。经过若干轮抵消后,最终留下的候选者必然属于多数派,即精明人。
例如,假设有三个人 。如果 说 是糊涂人,而 也说 是糊涂人,则 和 至少有一个是糊涂人。程序将同时淘汰 和 。由于三人里至少有两个精明人,我们确定 是精明人。
试补全程序。

- ① 处应填( )。 {{ select(39) }}
- ② 处应填( )。 {{ select(40) }}
- ③ 处应填( )。 {{ select(41) }}
- ④ 处应填( )。 {{ select(42) }}
- ⑤ 处应填( )。 {{ select(43) }}