22

已结束 IOI 开始于: 2025-11-19 10:30 2 小时 主持人: 1

C++ 一级 - 2025年09月

一、单选题(每题2分,共30分)

第1题
人工智能现在非常火,小杨就想多了解一下,其中就经常听人提到"大模型"。那么请问这里说的"大模型"最贴切是指( )。

  • [ ] A. 大电脑模型
  • [ ] B. 大规模智能
  • [ ] C. 智能的单位
  • [ ] D. 大语言模型

第2题
小杨这学期刚开学就选修了一门编程课,然后就想编写程序来计算1到10001之间的所有偶数的和。他希望程序采用简单累加整数的方法,同时希望源程序尽可能清晰、简洁,则下面关于实现累加时采用的主要控制结构的哪个说法最不合适( )。

  • [ ] A. 使用循环结构
  • [ ] B. 使用循环和分支的组合
  • [ ] C. 仅使用顺序结构
  • [ ] D. 不使用分支结构

第3题
下面的C++代码用于输入姓名,然后输出姓名,正确的说法是( )。

string XingMing;
cout << "请输入您的姓名: ";
cin >> XingMing;
cout << XingMing;
  • [ ] A. XingMing 是汉语拼音,不能作为变量名称
  • [ ] B. 可以将 XingMing 改为 Xing Ming
  • [ ] C. 可以将 XingMing 改为 xingming
  • [ ] D. 可以将 XingMing 改为 Xing-Ming

第4题
下列C++代码中a和b都是整型变量,执行后,其结果是( )。

int a = 2, b = 3;
printf("%d", a * 10 + b);
  • [ ] A. 2 3
  • [ ] B. 23
  • [ ] C. 20
  • [ ] D. 以上都不准确

第5题
C++表达式 3 * 4 % 5 / 6 的值是( )。

  • [ ] A. 10
  • [ ] B. 5
  • [ ] C. 2
  • [ ] D. 0

第6题
下面的C++代码中变量N和M都是整型,则执行时如果先输入10并输入一个制表符后输入20并回车,其输出的数值是( )。

scanf("%d ", &N);
scanf("%d ", &M);
printf("{%d}", N + M);
  • [ ] A. {30}
  • [ ] B. 1020
  • [ ] C. {N+M}
  • [ ] D. 不输出,继续等待输入

第7题
当前是9月,编写C++代码求N个月后的月份。横线处应填入的代码是( )。

int N, M;
cin >> N;
M = ___________;
if (M == 0)
    printf("%d个月后12月", N);
else
    printf("%d个月后是%d月", N, M);
  • [ ] A. N % 12
  • [ ] B. 9 + N % 12
  • [ ] C. (9 + N) / 12
  • [ ] D. (9 + N) % 12

第8题
下面C++代码执行后的输出是( )。

int n = 0;
for (int i = 0; i < 100; i++)
    n += i % 2;
cout << n;
  • [ ] A. 5050
  • [ ] B. 4950
  • [ ] C. 50
  • [ ] D. 49

第9题
下面的C++代码执行后输出是( )。

int N = 0, i;
for (i = -100; i < 100; i++)
    N += i % 10;
cout << N;
  • [ ] A. 900
  • [ ] B. 100
  • [ ] C. 0
  • [ ] D. -100

第10题
下面C++代码执行后输出是( )。

int i;
for (i = 1; i < 5; i++) {
    if (i % 3 == 0)
        break;
    printf("%d# ", i);
}
if (i > 5) printf("END\n");
  • [ ] A. 1#2#
  • [ ] B. 1#2#END
  • [ ] C. 1#2
  • [ ] D. 1#2#3#4#END

第11题
下面的C++代码用于求N的镜面数(N的个位到最高位的各位数字依次反过来出现在数字中,但高位0将被忽略,不输出),如输入1234,则将输出4321,又如输入120,则将输出21,错误的选项是( )。

cout << "请输入个位数不为0的正整数:"; cin >> N;
rst = 0; // 保存逆序结果
while (___________){
    rst = rst * 10 + N % 10;
    N = N / 10;
}
cout << rst << endl;
  • [ ] A. N != 0
  • [ ] B. not (N == 0)
  • [ ] C. N = 0
  • [ ] D. N > 0

第12题
下面C++代码用于交换两个正整数a和b的值,不能实现交换的代码是( )。

  • [ ] A.
cout << "输入第一个正整数: ";
cin >> a;
cout << "输入第二个正整数: ";
cin >> b;
temp = a;
a = b;
b = temp;
cout << "a= " << a << " b= " << b << endl;
  • [ ] B.
cout << "输入第一个正整数: ";
cin >> a;
cout << "输入第二个正整数: ";
cin >> b;
a = a + b;
b = a - b;
a = a - b;
cout << "a= " << a << " b= " << b << endl;
  • [ ] C.
cout << "输入第一个正整数: ";
cin >> a;
cout << "输入第二个正整数: ";
cin >> b;
a = a ^ b;
b = a ^ b;
a = a ^ b;
cout << "a= " << a << " b= " << b << endl;
  • [ ] D.
cout << "输入第一个正整数: ";
cin >> a;
cout << "输入第二个正整数: ";
cin >> b;
a, b = b, a;
cout << "a= " << a << " b= " << b << endl;

第13题
下面C++代码用于获得正整数N的第M位数,约定个位数为第1位,如N等于1234,M等于2,则输出3。假设M的值是大于等于1且小于等于N的位数。横线处应填入的代码是( )。

int N, M, div = 1;
cout << "请输入一个正整数: ";
cin >> N;
cout << "请输入从右到左取第几位数: ";
cin >> M;
for (int i = 0; i < (M - 1); i++) div *= 10;
cout << (___________);
  • [ ] A. N % div / 10
  • [ ] B. N / div / 10
  • [ ] C. N % div % 10
  • [ ] D. N / div % 10

第14题
下面C++代码执行后输出是( )。

num = 0;
while (num <= 5) {
    num += 1;
    if (num == 3)
        continue;
    printf("%d# ", num);
}
  • [ ] A. 1#2#4#5#6#
  • [ ] B. 1#2#4#5#6
  • [ ] C. 1#2#3#4#5#6#
  • [ ] D. 1#2#3#4#5#6

第15题
下面C++代码用于记录多个输入数中的最大数和最小数(输入-999则输入结束),相关说法错误的是( )。

cin >> now_num;
min_num = max_num = now_num;
while (now_num != -999) {
    if (max_num < now_num)
        max_num = now_num;
    if (min_num > now_num)
        min_num = now_num;
    cin >> now_num;
}
cout << min_num << ' ' << max_num;
  • [ ] A. 程序运行时如果第一个数输入-999,则输出将是-999 -999
  • [ ] B. 程序输入过程中,如果输入的第一个数不是-999,则如果待输入的数据中没有-999,则程序能求出已输入整数中的最大数和最小数
  • [ ] C. 如果用于输入考试成绩,即成绩中不可能有-999,则程序能求出已输入成绩中的最高成绩和最低成绩
  • [ ] D. 可以将 cin >> now_num; 移动到 while (now_num != -999) { 下面,结果不变

二、判断题(每题2分,共20分)

第1题
在集成开发环境里调试程序时,要注意不能修改源程序,因为如果修改,就要终止调试、关闭该文件并重新打开,才能再次开始调试。( )

  • [ ] 正确
  • [ ] 错误

第2题
执行C++表达式 10 % 0.5 将报错,因为0.5所在位置只能是整数。( )

  • [ ] 正确
  • [ ] 错误

第3题
下面C++代码执行后将输出9。( )

for (i = 0; i < 10; i++)
    break;
cout << i;
  • [ ] 正确
  • [ ] 错误

第4题
下面C++代码执行后将输出55。( )

n = 0;
for (int i = 0; i > -10; i--)
    n = n + i * -1;
cout << n;
  • [ ] 正确
  • [ ] 错误

第5题
将下面C++代码中的L1行的 i = 0 修改为 i = 1,其输出与当前代码输出相同。( )

cnt = 0;
for (int i = 0; i < 100; i++) // L1
    cnt += i;
cout << cnt;
  • [ ] 正确
  • [ ] 错误

第6题
将下面C++代码中的 i < 10 修改为 i <= 10,其执行后输出相同。( )

int n, i;
n = i = 0;
while (i < 10) {
    n += i;
    i += 1;
}
cout << n;
  • [ ] 正确
  • [ ] 错误

第7题
下面的C++代码执行后将输出45。( )

int n, i;
n = i = 0;
while (i < 10) {
    i += 1;
    n += i;
}
cout << n;
  • [ ] 正确
  • [ ] 错误

第8题
执行C++代码 cout << (12 + 12.12) 将报错,因为12是int类型,而12.12是float类型,不同类型不能直接运算。( )

  • [ ] 正确
  • [ ] 错误

第9题
下面C++代码执行时将导致无限循环(也称死循环)。( )

int count = 0;
while (count < 5) {
    count += 1;
    if (count == 3)
        continue;
    cout << count << ' ';
}
  • [ ] 正确
  • [ ] 错误

第10题
下列C++代码用于求斐波那契数列,即第1个数为0,第2个数为1,从第三个数开始,依次是其前两个数之和。如果输入的值为大于1的正整数,该代码能实现所求。( )

cin >> n;
a = 0, b = 1;
for (int j = 0; j < n; j++) {
    cout << a << " ";
    b = b + a;
    a = b - a;
}
  • [ ] 正确
  • [ ] 错误
.problem { margin: 20px 0; padding: 15px; border: 1px solid #ddd; border-radius: 5px; background: #f9f9f9; } .problem pre { background: #f5f5f5; padding: 10px; border-radius: 3px; overflow-x: auto; }
状态
已结束
规则
IOI
题目
1
开始于
2025-11-19 10:30
结束于
2025-11-19 12:30
持续时间
2 小时
主持人
参赛人数
1