2025年3月 GESP C++ 3级认证考试真题(含编程操作题部分)
选 单选题(共 15 题,每题 2 分)
Base64 编码将每3字节的输入数据编码为 4 字节的输出数据。如果输入数据长度不是 3 的倍数,会用=号填
充。在Base64编码中,如果输入字符串的长度为10字节,编码后的字符串长度是多少( )
UTF-8 编码规则如下:
字节:0xxxxxxx
字节:110xxxxx 10xxxxxx
字节:1110xxxx 10xxxxxx 10xxxxxx
字节:11110xxx 10xxxxxx 10xxxxxx 10xxxxxx
以下哪个字节序列是合法的 UTF-8 编码( )
在 8 位二进制原码表⽰中,八进制数 -5 的二进制形式是什么( )
十进制数 111.111 的二进制表⽰可以是下面的( )。
在C++中,补码的主要作用是()
在C++中,一个8位有符号整数(使用补码表⽰)的范围是()
在C++中,以下代码的输出是什么()
int a = -5;
unsigned int b = a;
cout << b;
下列程序的作用是()
int main() {
int decimal = 25;
cout << oct << decimal;
return 0;
}
下面程序是将十进制转十六进制,横线处应该填入的是()
#include <iostream>
using namespace std;
int main() {
int decimal = 255;
——————————————————
return 0;
}
以下代码的说法正确的是什么( )
#include <iostream>
using namespace std;
int main() {
int a = 0b1101;
int b = 0b1011;
cout << (a ^ b);
return 0;
}
下面枚举法查找最大值索引程序中,横线处应该填写的是()
#include <iostream>
using namespace std;
int main() {
int arr[] = {3, 7, 2, 9, 5};
int maxIndex = 0;
for (int i = 1; i < 5; i++) {
————————————————————————————————
{
maxIndex = i;
}
}
cout << maxIndex;
return 0;
}
以下代码的功能是将数组中的奇数和偶数分别放在数组的前半部分和后半部分,横线处应该填入的是()
#include <iostream>
using namespace std;
int main() {
int arr[] = {1, 2, 3, 4, 5};
int left = 0, right = 4;
while (left < right) {
while (arr[left] % 2 == 1 && left < right) left++;
————————————————————————————————————————————————————
if (left < right) {
swap(arr[left], arr[right]);
}
}
for (int i = 0; i < 5; i++) {
cout << arr[i] << " ";
}
return 0;
}
下面程序最后能够得到HelloC++的是()
int main() {
string str = "HelloWorld";
___________________
cout << str;
return 0;
}
想要得到字符串world,下面程序横线处应该填入的是()
#include <iostream>
#include <string>
using namespace std;
int main() {
string str = "HelloC++";
_________________
_________________
return 0;
}
有 n 个正整数,假设一个正整数是美丽数字当且仅当该正整数是 9 的倍数但不是 8 的倍数。下面的程序是
编写计算 n 个正整数中美丽数字的数量,横线处应该填入的是()
for (int i = 1; i <= n; i++) {
cin >> a;
__________________________
cnt++;
}
判 判断题(共 10 题,每题 2 分)
判断一个三角形是否成立的条件只有:任意两边长度之和大于第三条边的长度
这段程序进行的是判断一个从键盘输入的字符的ASCII 是否是奇数,若是,输出 YES,否则,输出 NO
int main()
{
char x;
scanf("%c", &x);
int ASCII = (int)x;
cout << (x & 1 ? "YES" : "NO") << '\n';
return 0;
}
闰年的定义:
普通闰年:公历年份是 4 的倍数,且不是 100 的倍数的,为闰年(如 2004 年、2020 年等就是闰年)。
世纪闰年:公历年份是整百数的,必须是 400 的倍数才是闰年(如 1900 年不是闰年,2000 年是闰年)。
下面程序是判断是否是闰年的正确程序
cin>>n;
cout<<((n%4==0&&n%100!=0)||(n%400==0))?1:0;
return 0;
C++语句cout<<(n%15==0? "YES":"NO");能够判断一个整数能否被3和5同时整除
有n个同学,从中抽取任意个⼈数来参加学校组织的大合唱,共有2的n次幂个方法
若将一个正整数化为二进制数,在此二进制数中,我们将数字 1 的个数是偶数的这类二进制数称为 A 类数,
否则就称其为 B 类数。
例如:
(13) 10 =(1101) 2 ,其中 1 的个数为 3则称此数为 B 类数;
(10) 10 =(1010) 2 ,其中 1 的个数为 2,称此数为 A 类数;
判断(2025)10化为二进制后,1的个数为偶数个,因此2025为A类数。
该段程序将 n 不停地除以 2,并输出此时的商和余数,直到 n=0 为⽌。
long long n;
cin >> n;
while(n != 0) {
cout << n/2 << ' ' << n%2 << '\n';
n /= 2;
}
两个13进制的数A和B,在10进制下分别表⽰10和11。(A+B)13=(18)13,也就是说13进制数A加上13进
制数B,和是13进制数18。
k 进制,逢 k 进第二位, 进百位, 进千位;
CCF(十九进制) = 21AC(十三进制)(不区分大小写)
编 编程操作题(共 2 题,共 50 分)
试题名称:2025
时间限制:1.0 s | 内存限制:512.0 MB
题目描述
⼩ A 有⼀个整数 ,他想找到最⼩的正整数 使得下式成⽴:
其中 表⽰⼆进制按位与运算, 表⽰⼆进制按位或运算。如果不存在满⾜条件的 ,则输出 。
输入格式
⼀⾏,⼀个整数 。
输出格式
⼀⾏,⼀个整数,若满⾜条件的 存在则输出 ,否则输出 。
数据范围
对于所有测试点,保证 。
3.1.7 提示
其中:
表⽰按位与运算,运算符为 &。
表⽰按位或运算,运算符为 |。
试题名称:词频统计
时间限制:1.0 s | 内存限制:512.0 MB
题目描述
在⽂本处理中,统计单词出现的频率是⼀个常见的任务。现在,给定 个单词,你需要找出其中出现次数最多的单
词。在本题中,忽略单词中字母的⼤⼩写(即 Apple、apple、APPLE、aPPle 等均视为同⼀个单词)。
请你编写⼀个程序,输⼊ 个单词,输出其中出现次数最多的单词。
输入格式
第⼀⾏,⼀个整数 ,表⽰单词的个数;
接下来 ⾏,每⾏包含⼀个单词,单词由⼤⼩写英⽂字母组成。
输⼊保证,出现次数最多的单词只会有⼀个。
输出格式
输出⼀⾏,包含出现次数最多的单词(输出单词为⼩写形式)。
数据范围
对于所有测试点, ,每个单词的长度不超过 ,且仅由⼤⼩写英⽂字母组成。