2024年6月GESPC++三级真题解析

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

题目123456789101112131415
答案

C

B

C

C

C

B

C

C

C

B

A

C

B

D

A

1.⼩杨⽗母带他到某培训机构给他报名参加CCF组织的GESP认证考试的第1级 ,那他可以选择的认证语言有 ( )  种。

A. 1

B. 2

C. 3

D. 4

【答案】C

【考纲知识点】

【解析】可选语言:图形化编程、C++、Python

2.下⾯流程图在yr输⼊2024时,可以判定yr代表闰年,并输出2月是29天,则图中菱形框中应该填入( )。

 

A. (yr%400==0) || (yr%4==0)

B. (yr%400==0) || (yr%4==0 && yr%100 !=0)

C. (yr%400==0) && (yr%4==0)

D.(yr%400==0) && (yr%4==0 && yr%100 !=0)

【答案】B

【考纲知识点】

【解析】判断闰年,闰年定义:

普通闰年:公历年份是4的倍数,且不是100的倍数的, 为闰年(如2004年、2020年等就是闰年)。

世纪闰年:公历年份是整百数的,必须是400的倍数才是 闰年(如1900年不是闰年,2000年是闰年)。

3.⼀般默认64位计算机系统中整型变量(int)还是32位 ,则整数能够表⽰的数据范围是( )。
A.0~ 232

B.0~ 264

C.-231~(231)-1

D.-263~ (263)-1

【答案】C

【考纲知识点】

【解析】int一32位,其中1位为符号位,其余31位表示数值,范围231 ~(231)-1

4.下列代码将⼗进制转化成⼋进制 ,则横线上应填⼊(    )。
#include <iostream>

using namespace std;

void decimal2octal(int decimal) {

int oct_number[100];

int i = 0;

while (decimal > 0) {

__________________________ //在此处填入代码

}

for (int j = i - 1; j >= 0; j--) {

cout << oct_number[j];

}

cout << endl;

}

A.oct_number[i] = decimal % 8;    decimal /= 8;    

B.oct_number[i] = decimal / 8;    decimal %/= 8;  

C.oct_number[i++] = decimal % 8;    decimal /= 8;  

D.oct_number[i++] = decimal / 8;    decimal %= 8;

【答案】C

【考纲知识点】

【解析】每放入一个数值,i需要+1,即需要使用oct_number[i ++],存入的数值为整除8之后的余数,即decimal % 8,然后decimal需要重新赋值为整除8之后的值

5.二进制数101. 11对应的⼗进制数是(  )。

A. 6.5

B. 5.5

C. 5.75

D. 5.25
【答案】C

【考纲知识点】

【解析】按位权展开,整数末尾位为R0,向高位递增,低位递减,因此

1 0  1  .1  1

22 2120  2-12-2

1*22+0*21+1*20+1*2-1+1*2-2=5.75

6.下列流程图的输出结果是( ) 。


 

A.5

B.10

C.20

D.30
【答案】B

【考纲知识点】

【解析】

嵌套循环语句,外层循环5 次,i的值从0~4,内层循环i次,j 从0~i,内层循环一次sum增加1,即sum记录内层循环的循环次数sum=0 +1+2+3+4=10

流程图可转换成下方代码:
int sum=0,i=0;

while(i<5){

int j=0;

while(j<i){

sum++;

j++;

}

i++;

}

cout<<sum;

7.下列代码的输出结果是( )。
#include <iostream>

using namespace std;

int main() {

int a = 12;

int result = a >> 2;

cout << result << endl;

return 0;

}

A.12

B.6

C.3

D.1

【答案】C

【考纲知识点】

【解析】>>2快速计算为除以22,然后向下取整,即12/4=3,需要注意,如果输入的数不够除以2,会输出0

8.下列代码的输出结果是( )。

#include <iostream>

using namespace std;

int main() {

int a = 5;

int b = 10;

a = a ^ b;

b = a ^ b;

a = a ^ b;

cout << "a = " << a << ", b = " << b << endl;

return 0;

}

A. a = 5, b = 10

B. a = 5, b = 5

C. a = 10, b = 5

D. a = 10, b = 10
【答案】C

【考纲知识点】

【解析】本题使用异或^来交换两个变量的值

9.如果字符串定义为char str[] = "GESP";  ,则字符数组str的长度为( )。

A. 0

B. 4

C. 5

D. 6

【答案】C

【考纲知识点】

【解析】"GESP"除了四个字符,末尾还有不可见字符'\0'

10.在下列代码的横线处填写( ) ,可以使得输出是“7”。
#include <iostream>

using namespace std;

int main() {

int array[5] = {3,7,5,2,4};

int max = 0;

for(int i=0; i<5; i++)

if(______________) // 在此处填入代码

max = array[i];

cout << max << endl;

return 0;

}

A. max > array[i]

B. max < array[i]

C. max = array[i]

D. 以上均不对
【答案】B

【考纲知识点】

【解析】计算最大值,打擂台,如果array[i]比max更大, max记录array[i]的值

11.⼩杨在做数学题 ,题⽬要求找出从1到35中能被7整除的数字, 即[7, 14, 21, 28, 35] ,则横线处应填⼊哪个代码? ( )
#include <iostream>

using namespace std;

int main() {

int arr[35];

int count = 0;

for (int i = 1; i <= 35; i++) {

if (i % 7 == 0)

__________________________ // 在此处填入代码

}

for (int i = 0; i < count; i++)

cout << arr[i] << endl;

return 0;

}

A. arr[count++] = i;

B. arr[i] = count++;

C. arr[i] = count;

D. arr[count] = count++;
【答案】A

【考纲知识点】

【解析】count变量用于记录当前已经储存的数的个数,也可做下标, 初始值为0,记录数值i之后+1,即arr[count++]=i。

12.已知字符 '0' 的ASCII编码的⼗进制表⽰为48 ,则执⾏下⾯C++代码后 ,输出是( )。
#include <iostream>

using namespace std;

int main() {

string s = "0629";

int n = s.length();

int x = 0;

for(int i = 0; i < n; i++)

x += s[i];

cout << x << endl;

return 0;

}

A. 17

B. 158

C. 209

D. 316
【答案】C

【考纲知识点】

【解析】本题计算字符串s中所有字符的ASCII码的和,

x=48+(48+6)+(48+2)+(48+9)

 =48*4+(6+2+9)

 =209

13.某⼩学男⼦篮球队招募新成员 ,要求加⼊球队的成员⾝⾼在135厘⽶以上(不含135厘⽶) 。本次报名的⼈ 员有10⼈ ,他们的⾝⾼分别是125 、 127 、 136 、 134 、 137 、 138 、 126 、 135 、 140 、 145 。完善以下代码 ,求出本次球队能够招募到新成员的⼈数? ( )
#include <iostream>

using namespace std;

int main() {

int arr[10] = {125, 127, 136, 134, 137, 138, 126, 135, 140, 145};

int count = 0;

for(int i=0; i<10; i++)

__________________________ // 在此处填入代码

cout << count << endl;

return 0;

}

A. count = arr[i]>135? 1: 0;

B. count += arr[i]>135? 1: 0;

C. count++;

D. 以上都不对
【答案】B

【考纲知识点】

【解析】三目运算符:条件?条件成立:条件不成立 本题为arr[i]>135那么count+=1,否则count+=0

14.下⾯可以正确输出They 're planning a party for their friend 's birthday. 的C++语句是?(    )
A. cout << 'They\ 're planning a party for their friend'\s birthday." << endl;  

B.  cout << "They\ 're planning a party for their friend 's birthday. '<< endl;   

C. cout << 'They 're planning a party for their friend 's birthday. '<< endl;

D. cout << "They\ 're planning a party for their friend\ 's birthday." << endl;

【答案】D

【考纲知识点】

【解析】C++中字符串为成对的双引号;另外考察转义字符,由于'有特殊含义,因此可以使用\ '来转义输出('可用可不用,有些特殊字符必须加转义字符\)

15.如果执⾏下⾯C++代码后 ,输出的结果是“gesp ccforg cn ” ,则横线上应填⼊哪个代码? ( )

A. str = str.substr(found + delimiter.length(), str.length() - 1);

B. str = str.substr(found, str.length() );    

C. str = str.substr(found, str.length() -1);  

D.以上都不对
【答案】A

【考纲知识点】

【解析】缺失部分为保留找到的第一个delimiter之后的字符, 因此从found+delimiter.length()开始截取,直到最后

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

题目12345678910
答案

×

×

×

×

1.GESP测试是对认证者的编程能⼒进⾏等级认证, 同⼀级别的能⼒基本上与编程语⾔⽆关。

【答案】正确

【考纲知识点】

【解析】本题考察对GESP的认识,GESP认证是对认证者的编程能力进行等级认证, 同⼀级别的能力基本上与编程语言无关

2.整数-6的16位补码可⽤⼗六进制表⽰为FFFA 。

【答案】正确

【考纲知识点】

【解析】6 =(1000 0000 0000 0110)原

=(1111 1111 1111 1001友

=(1111 1111 1111 1010)补

使用四位对一位快速转换,对应16进制补码FFFA

3.补码的优点是可以将减法运算转化为加法运算 ,从⽽简化计算机的硬件设计。

【答案】正确

【考纲知识点】

【解析】例如计算1-1就可以转化为1 + (-1) 的补码

4.字符常量'\0'常⽤来表⽰字符串结束 ,和字符常量'0'相同。

【答案】错误

【考纲知识点】

【解析】'\0'表示字符串结束,ASCII码为0,字符'0' ASCII为48

5.数组的所有元素在内存中可以不连续存放 。

【答案】错误

【考纲知识点】

【解析】数组无论是物理上(内存),还是逻辑上(下标),均是连续的

6.C++中可以对数组和数组的每个基础类型的元素赋值 。  

【答案】错误

【考纲知识点】

【解析】数组中的元素可以赋值,数组不行
 

7.如果为int类型的变量 ,且表达式 ((a | 3) == 3) 的值为true,则说明在从0到3之间(可能为0、可能为3) 。

【答案】正确

【考纲知识点】

【解析】((a|3)==3)表示a的2进制数后除后两位均为0 ,后两位值不限,因此范围0~3,包含0和3

8.执⾏下⾯C++代码后 ,输出的结果是8。
int a = 0b1010;

int b = 01100;

int c = a & b;

cout << c <<endl;

【答案】错误

【考纲知识点】

【解析】a为2进制1010,0b为2进制表示形式b为8进制1100,0为8进制的表示形式

9.执⾏下⾯C++代码后 ,输出的结果不可能是89781。( )
#include <iostream>

#include <cstdlib> // 为了使用 rand() 和 srand()

#include <ctime> // 为了使用 time()

using namespace std;

int main() {

// 设置随机种子

srand(time(NULL));

int i = 1;

int s[5];

while(i <= 5)

{

int a = rand() % 10;

if(a % 3 == (i + 1) % 3)

s[i++] = a;

}

for(int i = 1; i <= 5; i++)

cout << s[i];

cout << endl;

return 0;

}

【答案】正确

【考纲知识点】

【解析】限制a为0~9之间的随机数

i和(i+1)%3的对应关系:

i    1 2 3 4 5

(i+1)%32 0 1 2 0

当(i+1)%3值为0时,a可以为0、3、6、9

当(i+1)%3值为1时,a可以为1、4、7

当(i+1)%3值为2时,a可以为2、5、8

因此第一位可以为2、5、8,第二位可以为0、3、6、9,第三位可以为1、4、7,第四位可以为2、5、8,第五位可以为0、3、6、9因此89781的最后一位不符合

10.把整数3025从中剪开分为30和25两个数 ,此时再将这两数之和平⽅ ,计算结果⼜等于原数 。(30 + 25) × (30 + 25)= 55 × 55 = 3025 ,这样的数叫“雷劈数” 。可以使⽤枚举的⽅法求出所有符合这样条件的四位数 。( )

【答案】正确

【考纲知识点】

【解析】枚举:列举所有情况,找出符合要求的情况。

三、编程题(每题25分,共50分)

 

1、移位

【问题描述】

⼩杨学习了加密技术移位 ,所有⼤写字母都向后按照⼀个固定数⽬进⾏偏移 。偏移过程会将字母表视作⾸尾相接的环,例如,当偏移量是3的时候,⼤写字母A会替换成D⼤写字母Z会替换成C,总体来看,⼤写字母表ABCDEFGHIJKLMNOPQRSTUVWXYZ会被替换成DEFGHIJKLMNOPQRSTUVWXYZABC。

注:当偏移量是26的倍数时,每个⼤写字母经过偏移后会恰好回到原来的位置, 即⼤写字母表 ABCDEFGHIJKLMNOPQRSTUVWXYZ经过偏移后会保持不变。

【输入描述】

第⼀⾏包含⼀个正整数n。

【输出描述】

输出在偏移量为n的情况下 ,⼤写字母表 ABCDEFGHIJKLMNOPQRSTUVWXYZ移位替换后的结果。

【样例输入 1】

3

【样例输出 1】

DEFGHIJKLMNOPQRSTUVWXYZABC

【题目大意】

当偏移量是3的时候 ,⼤写字母 A会替换成D,⼤写字母Z会替换成C,总体来看 ,⼤写字母表 ABCDEFGHIJKLMNOPQRSTUVWXYZ会被替换成DEFGHIJKLMNOPQRSTUVWXYZABC。

【考纲知识点】

【解题思路】

周期问题,字符的原始位置是i,向右移动n个字符即等于(i+n)%26;

【参考程序】
#include<bits/stdc++.h>

using namespace std;

int main(){

int n;

cin>>n;

for(int i=0;i<26;i++){

int j = (i+n)%26;

char ch = 'A'+j;

cout<<ch;

}

cout<<"\n";

}

2、寻找倍数

【问题描述】

⼩杨有⼀个包含n个正整数的序列A= [a1 , a2 , … , an],他想知道是否存在i (1 ≤ i ≤ n) 使得ai是序列A中所有数的倍数。

【输入描述】

第一行包含一个正整数t,代表测试用例组数。

接下来是t组测试用例。

对于每组测试用例,一共两行。其中,第一行包含一个正整数n;第二行包含几个正整数,代表序列A。

【输出描述】

对于每组测试用例,如果存在i(1≤i≤n)满⾜对于所有k(1≤k≤n)ai是ak的倍数,输出Yes,否则输出No。

【样例输入 】

2

3

1 2 4

5

1 2 3 4 5

【样例输出 】

Yes

No

【题目大意】

【考纲知识点】

【解题思路】

因为1≤ai ≤10^9

如果ai为序列中所有元素的倍数,那么ai必定大于等于序列中其他元素。

【参考程序】
#include<bits/stdc++.h>

using namespace std;

const int N = 1e5+10;

int a[N];

int main(){

int t;

cin>>t;

while(t--){

int n;

cin>>n;

int x = 0;

for(int i=1;i<=n;i++){

cin>>a[i];

x =max(x,a[i]);

}

int fl = 0;

for(int i=1;i<=n;i++){

if(x%a[i])fl=1;

}

if(fl)cout<<"No\n";

else cout<<"Yes\n";

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值