#TK1163. 2025年9月CCF-GESP编程能力等级认证C++编程一级真题

2025年9月CCF-GESP编程能力等级认证C++编程一级真题

GESP C++ 一级 2025年09月考试试卷

1 单选题(每题 2 分,共 30 分)

第 1 题

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

{{ select(1) }}

  • 大电脑模型
  • 大规模智能
  • 智能的单位
  • 大语言模型

第 2 题

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

{{ select(2) }}

  • 使用循环结构
  • 使用循环和分支的组合
  • 仅使用顺序结构
  • 不使用分支结构

第 3 题

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

string XingMing; 
cout << "请输入您的姓名:";
cin >> XingMing;
cout << XingMing;

{{ select(3) }}

  • XingMing 是汉语拼音,不能作为变量名称
  • 可以将 XingMing 改为 Xing Ming
  • 可以将 XingMing 改为 xingming
  • 可以将 XingMing 改为 Xing-Ming

第 4 题

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

a = 13; 
b = 5;
cout << a / b << a % b << a % b;
a*b;

{{ select(4) }}

  • 2 3
  • 23
  • 20
  • 以上都不准确

第 5 题

C++表达式 3 * 4 % 5 / 6 的值是( )。 {{ select(5) }}

  • 10
  • 5
  • 2
  • 0

第 6 题

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

scanf("%d", &N); 
scanf("%d", &M); 
printf("{%d}",N+M);

{{ select(6) }}

  • {30}
  • 1020
  • {N+M}
  • 不输出,继续等待输入

第 7 题

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

int N, M;
cin >> N;
M = _____________ ;
if (M == 0) printf("%d个月后12月", N);
else printf("%d个月后是%d月", N, M);

{{ select(7) }}

  • N % 12
  • 9 + N % 12
  • (9 + N) / 12
  • (9 + N) % 12

第 8 题

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

int n = 0;
for (int i =0; i < 100; i++)
    cout << n; 
n += i % 2;

{{ select(8) }}

  • 5050
  • 4950
  • 50
  • 49

第 9 题

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

int N = 0, i; 
for (i = -100; i < 100; i++)
    cout << N; 
N += i % 10;

{{ select(9) }}

  • 900
  • 100
  • 0
  • -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");
}

{{ select(10) }}

  • 1#2#
  • 1#2#END
  • 1#2
  • 1#2#3#4#END

第 11 题

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

cin >> N; 
rst = 0; // 保存逆序结果 
cout << "请输入个位数不为0的正整数:";
while (______________){
    rst = rst * 10 + N % 10;
    N = N / 10;
    cout << rst << endl;
}

{{ select(11) }}

  • N != 0
  • not (N == 0)
  • N = 0
  • N > 0

第 12 题

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

  • cout << "输入第一个正整数: "; 
    cin >> a; 
    cout <<"输入第二个正整数: "; 
    cin >> b; 
    temp = a;
    a = b; 
    b = temp; 
    cout << "a=" << a << " b=" << b << endl;
    
  • cout << "输入第一个正整数: ";
    cin >> a;
    cout <<"输入第二个正整数: "; 
    cin >> b;
    b = a - b; 
    a = a - b;
    b = a + b;
    cout << "a=" << a << " b=" << b << endl;
    
  • cout << "输入第一个正整数: "; 
    cin >> a;
    cout <<"输入第二个正整数: ";
    cin >> b;
    b = a - b; 
    a = a + b;
    a = a - b;
    cout << "a=" << a << " b=" << b << endl;
    
  • 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 << (______________);

{{ select(13) }}

  • N % div / 10
  • N / div / 10
  • N % div % 10
  • N / div % 10

第 14 题

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

num = 0; 
while (num <= 5){
    num += 1;
    if (num == 3)
        printf("%d#", num); 
    continue;
}

{{ select(14) }}

  • 1#2#4#5#6#
  • 1#2#4#5#6
  • 1#2#3#4#5#6#
  • 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;

{{ select(15) }}

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

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

第 16 题

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

  • 正确
  • 错误

第 17 题

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

  • 正确
  • 错误

第 18 题

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

for (i = 0; i < 10; i++)
    cout << i; 
break;

{{ select(18) }}

  • 正确
  • 错误

第 19 题

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

n = 0; 
for (int i = 0; i > -10; i--)
    n = n + i * -1;
cout << n;

{{ select(19) }}

  • 正确
  • 错误

第 20 题

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

cnt = 0; 
for (int i = 0; i < 100; i++) // L1
    cout << cnt; 
cnt += i;

{{ select(20) }}

  • 正确
  • 错误

第 21 题

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

int n,i;
n=i=0; 
while (i<10){ 
    n+=i;
    i+=1;
}
cout<<n;

{{ select(21) }}

  • 正确
  • 错误

第 22 题

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

int n,i;
n=i=0; 
while (i<10){
    i+=1;
    n+=i;
}
cout<<n;

{{ select(22) }}

  • 正确
  • 错误

第 23 题

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

  • 正确
  • 错误

第 24 题

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

int count=0;
while (count<5){
    count+=1;
    if(count ==3)
        cout << count<<' '; 
    continue;
}

{{ select(24) }}

  • 正确
  • 错误

第 25 题

下列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;
}

{{ select(25) }}

  • 正确
  • 错误