#X000211. GESP C++ 二级试卷(2025年09月)

GESP C++ 二级试卷(2025年09月)

GESP C++ 二级模拟试卷(2025年09月)

一、选择题

本试卷共15道单项选择题,考察基本语法、逻辑结构和简单算法。


第1题

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

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

第2题

在TCP协议中,完成连接建立需要通过( )握手。 {{ select(2) }}

  • 一次
  • 二次
  • 三次
  • 四次

第3题

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

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

{{ select(3) }}

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

第4题

下面C++代码用于获得正整数N的第M位数,如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(4) }}

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

第5题

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

int a=3, b=4;
int c = a == b;
cout << a << ' ' << b << ' ' << c;

{{ select(5) }}

  • 3 4 0
  • 3 3 3
  • 4 4 4
  • 以上都不对

第6题

某种编号的规则是"XX-Y",其中XX从00到11,Y从0到9。第1个编号是00-0,第2个编号是01-1,…,第12个编号11-1,第13个编号00-2,即其编码规则是XX和Y同时增1,到XX到11时下一个变为00,Y到9时,下一个变为0。下面的C++代码用于生成第N个编号,横线处应填上的代码是( )。

int N, part1, part2;
cout << "请输入编号位置:";
cin >> N;
part1 = N % _____;
part2 = N % _____;
if (part1 < 10)
    printf("0%d-%d\n", part1, part2);
else
    printf("%d-%d\n", part1, part2);

{{ select(6) }}

  • 12 10
  • 10 10
  • 11 9
  • 9 9

第7题

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

int cnt = 0;
for (int i=-10; i<10; i++)
    for (int j=0; j<i; j++)
        cnt += 1;
cout << cnt;

{{ select(7) }}

  • 145
  • 125
  • 55
  • 45

第8题

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

int i, j;
for (i=1; i<12; i++) {
    if (i%2==0) continue;
    for (j=0; j<i; j++)
        if (i*j%2) break;
}
if (i>=12)
    cout << (i*j);

{{ select(8) }}

  • 110
  • 12
  • 不确定
  • 无输出

第9题

阅读下面的C++代码,其中变量都是整型,则说法正确的是( )。

int a, b, remainder;
cin >> a >> b;
while (b != 0) {
    remainder = a % b;
    a = b;
    b = remainder;
}
cout << a;

{{ select(9) }}

  • b不能为0,因为a % b将导致错误
  • a必须小于b,否则a % b将导致错误
  • a和b都必须为正整数,否则a % b将导致错误
  • 如果a输入为0,则不管b的输入值是什么,输出值的绝对值都是abs(b)

第10题

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

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

{{ select(10) }}

  • 1#2#4#5#6#
  • 1#2#4#5#6
  • 1#2#3#4#5#6#
  • 1#2#3#4#5#6

第11题

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

int now_num, min_num, max_num;
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(11) }}

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

第12题

下面C++代码执行后输出与5有关数的数量。"与5有关的数"定义为含有5或者能被5整除的数。相关说法正确的是( )。

int cnt=0, i, j;
for (i=1; i<1000; i++) {
    if (i%5==0) { cnt+=1; continue; }
    j = i;
    while (j>0) {
        if (j%10==5) { cnt+=1; break; }
        else j/=10;
    }
}
cout << cnt;

{{ select(12) }}

  • 删除代码中continue不影响程序执行结果
  • 删除j=i并将while循环内的j修改为i,不影响程序执行结果
  • 代码中break修改为j=0,不影响程序执行结果
  • 将while(j>0)修正为while(j>=0)不影响程序执行的结果

第13题

下面C++代码实现输出如下图形,应该在横线处填入的代码是( )。

请输入层数:10
         1
        23
       456
      7891
     23456
    789123
   4567891
  23456789
 123456789
1234567891
int N, K=1;
cout << "请输入层数:";
cin >> N;
for (int i=1; i<N+1; i++) {
    for (int _=1; _<___________; _++) cout << " ";
    for (int _=1; _<________; _++) {
        cout << K;
        K+=1;
        if (K==10) K=1;
    }
    cout << '\n';
}

{{ select(13) }}

  • N-i+1和i+1
  • N-i和i
  • N和i
  • N-i和i+1

第14题

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

int a=9, b=27;
a = 'a' + 'b';
b = 'a' - 'b';
a = a - b;
cout << a << ' ' << b << endl;

{{ select(14) }}

  • 196 -1
  • 27 9
  • 98 97
  • 不确定

第15题

有个无限长的链,由3种外形相同但材质不同的环链成。3种环的重量分别是3、4、6克,相同材质的多个环每12克一组,分别记为G3、G4、G6。链依次G3、G4、G6、G3、G4、G6、…。同时对链上所有环从头依次编号1、2、3、4……。输入正整数代表环编号,求该编号前所有环(不含该环本身)的重量。下面是C++代码是实现,正确说法是( )。

int N, G, R;
int wc = 0;
cin >> N; // 输入正整数
G = (N-1)/9; // L1
R = (N-1)%9; // L2:保存余数
wc += 36*G;
if ((1<=R) && (R<=4))
    wc += 3*R; // L3
else if ((5<=R) && (R<=7))
    wc += 4*R; // L4
else if (R==8)
    wc += 6*(R-1); // L5
cout << wc << endl;

{{ select(15) }}

  • 必须同时修改L1和L2代码行才能实现功能
  • 必须同时修改L3和L4代码行才能实现功能
  • 必须同时修改L3和L5代码行才能实现功能
  • 其他说法都不对

二、判断题


第16题

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

  • 正确
  • 错误

第17题

在C++代码中,假设N为正整数且大于100,则N/100将舍弃个位和十位,如N为1234则cout << (N/100)将输出12。如果N小于100,则其值为0。 {{ select(17) }}

  • 正确
  • 错误

第18题

下列C++代码执行后将输出1,因为a确实小于20和10。

int a = 5;
cout << (a < 10 and 20);

{{ select(18) }}

  • 正确
  • 错误

第19题

下面的C++代码中变量都是整型,则执行后将输出1。

int x=5, y=10, z=15;
bool result = x < y < z;
cout << result;

{{ select(19) }}

  • 正确
  • 错误

第20题

下面C++代码执行时如输入99.99,将输出"及格"两个汉字。

int score;
cout << "请输入学生成绩:";
cin >> score;
if (score >= 60) printf("及格");
else printf("不及格");

{{ select(20) }}

  • 正确
  • 错误

第21题

执行下面的C++代码时输入123,则输出是DCB。

int a;
cin >> a;
while(a) {
    cout << 'A' + a%10;
    a /= 10;
}

{{ select(21) }}

  • 正确
  • 错误

第22题

下面的C++代码执行后将输出" +#+#3#"。

int i;
for (i = 0; i < 3; i++){
  if (i == 2)
    continue;
  printf("+#");
}
cout << i << '#';

{{ select(22) }}

  • 正确
  • 错误

第23题

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

int n, a=0, b=1, c;
cin >> n;
if (n==1) cout << a;
else if (n==2) cout << b;
else {
    for (int i=3; i<=n; i++) { c=a+b; a=b; b=c; }
    cout << c;
}

{{ select(23) }}

  • 正确
  • 错误

第24题

下面的C++不能实现如下输出,但如果将L1标记的cout << 0行移动if块外面,或者说移动到L2标记行,则可以。

请输入矩阵大小n: 9
100000000
020000000
003000000
000400000
000050000
000006000
000000700
000000080
000000009
  
int n, i, j;
cout << "请输入矩阵大小n: ";
cin >> n;
for (i = 0; i < n; i++){
  for (j = 0; j < n; j++){
    if (i == j){
      cout << i + 1;
      continue;
      cout << 0; // L1
    }// L2
}
printf("\n");
}

{{ select(24) }}

  • 正确
  • 错误

第25题

C++代码cout << ('5'+4);执行后的输出为9。 {{ select(25) }}

  • 正确
  • 错误