CCF编程能力等级认证GESP—C++3级—20240629

news2025/1/23 22:41:03

CCF编程能力等级认证GESP—C++3级—20240629

  • 单选题(每题 2 分,共 30 分)
  • 判断题(每题 2 分,共 20 分)
  • 编程题 (每题 25 分,共 50 分)
    • 移位
    • 寻找倍数

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

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

A. 1
B. 2
C. 3
D. 4

正确答案:C

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)

正确答案:V

3、一般默认64位计算机系统中整型变量(int)还是32位,则整数能够表示的数据范围是( )。

A . 0 A. 0 A.0 ~ 2 32 2^{32} 232
B . 0 B. 0 B.0 ~ 2 64 2^{64} 264
C . − 2 31 C. - 2^{31} C.231 ~ 2 31 − 1 2^{31} - 1 2311
D . − 2 63 D. - 2^{63} D.263 ~ 2 63 − 1 2^{63} - 1 2631

正确答案:C

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

5、二进制数101.11对应的十进制数是( )。

A. 6.5
B. 5.5 
C. 5.75 
D. 5.25

正确答案:C

6、下列流程图的输出结果是( ) 。
在这里插入图片描述

A. 5 
B. 10 
C. 20 
D. 30

正确答案:B

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

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

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

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

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

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

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

15、如果执行下面C++代码后,输出的结果是“gesp ccf org cn ”,则横线上应填入哪个代码?( )

#include <iostream>
using namespace std;
int main() {
    string str = "gesp.ccf.org.cn";
    string delimiter = ".";
    string result="";
    string token;
    size_t found = str.find(delimiter);
    while (found != string::npos)  {
        token = str.substr(0, found);
        result += token;
        result += " ";
        __________________________ // 在此处填入代码 
        found = str.find(delimiter);
    }
    //最后一部分 
    result += str;
    result += " ";
    cout << result << endl;
    return 0; 
}
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

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

1、GESP测试是对认证者的编程能力进行等级认证,同一级别的能力基本上与编程语言无关。

正确答案:正确

2、整数-6的16位补码可用十六进制表示为FFFA。

正确答案:正确

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

正确答案:正确

4、字符常量’\0’常用来表示字符串结束,和字符常量’0’相同。

正确答案:错误

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

正确答案:错误

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

正确答案:错误

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

正确答案:正确

8、执行下面C++代码后,输出的结果是8。

int a = 0b1010;
int b = 01100;
int c = a & b;
cout << c << endl;

正确答案:错误

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

正确答案:正确

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

正确答案:正确

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

移位

【问题描述】
小杨学习了加密技术移位,所有大写字母都向后按照一个固定数目进行偏移。偏移过程会将字母表视作首尾相接的 环,例如,当偏移量是3的时候,大写字母 A 会替换成 D,大写字母 Z 会替换成 C,总体来看,大写字母表ABCDEFGHIJKLMNOPQRSTUVWXYZ 会被替换成 DEFGHIJKLMNOPQRSTUVWXYZABC。
注:当偏移量是26的倍数时,每个大写字母经过偏移后会恰好回到原来的位置,即大写字母表ABCDEFGHIJKLMNOPQRSTUVWXYZ 经过偏移后会保持不变。
【输入描述】
第一行包含一个正整数n 。
【输出描述】
输出在偏移量为n的情况下,大写字母表 ABCDEFGHIJKLMNOPQRSTUVWXYZ 移位替换后的结果。
【样例输入 1】
3
【样例输出 1】
DEFGHIJKLMNOPQRSTUVWXYZABC
【样例解释】
当偏移量是3的时候,大写字母 A 会替换成 D,大写字母 Z 会替换成 C,总体来看,大写字母表
ABCDEFGHIJKLMNOPQRSTUVWXYZ 会被替换成 DEFGHIJKLMNOPQRSTUVWXYZABC。
【数据范围】
对于全部数据,保证有1 <= n <= 100 。

#include <iostream>

using namespace std;

int main(){
	int n;
	cin >> n;
	for (char i = 'A'; i <= 'Z'; i++){
		char tmp = i + n % 26;
		if (tmp > 'Z')
			tmp -= 26;
		cout << tmp;
	}
	return 0;
}

寻找倍数

【问题描述】
小杨有一个包含n个正整数的序列 A = [ a 1 , a 2 , . . . , a n ] A = {[a_1, a_2, ..., a_n]} A=[a1,a2,...,an] ,他想知道是否存在 i(1 <= i <= n ) 使得 a i a_i ai是序列A中所有数的倍数。
【输入描述】
第一行包含一个正整数t,代表测试用例组数。
接下来是t组测试用例。
对于每组测试用例,一共两行。其中,第一行包含一个正整数n;第二行包含n个正整数,代表序列A。
【输出描述】
对于每组测试用例,如果存在i(1<=i<=n)满足对于所有k(1<=k<=n) a i 是 a k 的倍数 a_i是a_k的倍数 aiak的倍数,输出Yes,否则输出N哦
【样例输入 1】
2
3
1 2 4
5
1 2 3 4 5
【样例输出 1】
Yes
No
【样例解释】
对于第一组数据,对于 a 3 = 4 a_3 = 4 a3=4 ,满足 a 3 是 a 1 和 a 2 的倍数 a_3是a_1和a_2的倍数 a3a1a2的倍数
【数据范围】
对于全部数据,保证有 1 < = t < = 10 , 1 < = n < = 1 0 5 , 1 < = a i < = 1 0 9 1<=t<=10, 1<=n<=10^5, 1 <= a_i <= 10^9 1<=t<=10,1<=n<=105,1<=ai<=109

#include <iostream>

using namespace std;
const int maxn = 1e5 + 10;
int main(){
	int t, n, a[maxn];
	cin >> t;
	for (int ci = 1; ci <= t; ci++){
		cin >> n;
		bool is_f;
		for (int i = 1; i <= n; i++){
			cin >> a[i];
		}
		for (int i = 1; i <= n; i++){
			is_f = true;
			for (int j = 1; j <= n; j++){
				if (a[i] % a[j] != 0){
					is_f = false;
					break;
				}
			}
			if (is_f){ // 如果找到了提前输出并退出
				cout << "Yes\n";
				break;
			}
		}
		if (!is_f){
			cout << "No\n";
		}
	}
		return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1975803.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【基础篇】MySQL数据库详解:基础知识详解

一、SQL分类 1.DDL2.DML3.DQL4.DCL二、函数 1.字符串函数2.数值函数3.日期函数4.流程函数三、约束 1.概述2.约束演示3.外键约束四、多表查询 1.多表关系2.多表查询表述3.内连接4.外连接5.自连接6.子查询五、事务 1.事务简介2.事务操作3.事务四大特性4.并发事务问题5.事务隔离级…

C语言——求阶乘的两种方法

第一种方法使用了递归思想 #include <stdio.h> int fun(int N) {if (N 0){return 1;}else{return (fun(N - 1) * N);} } int main() {int N 0;scanf_s("%d", &N);printf("%d",fun(N)); } 第二种方法用的for循环 #include <stdio.h> i…

如何开启idea中的断言功能?

目录 一、什么是断言&#xff1f; 二、Java断言的语法 三、开启断言 一、什么是断言&#xff1f; 断言&#xff08;assert&#xff09;是 Java 中的一条语句&#xff0c;一种在程序中的逻辑&#xff08;如一个结果为真或假的逻辑判断式&#xff09;&#xff0c;目的是验证软…

Unity Shader unity文档学习笔记(十八):unity雾效原理

看很多文章用近平面远平面组成矩阵后转到裁剪空间下通过Z值来解&#xff0c;实际更简单的方式可以直接通过判断距离来实现 FogMgr控制远近面 public class TestFog : MonoBehaviour {public int startDis 0;public int endDis 50;public Vector4 fogParam;public void Awak…

springboot宠物宿舍管理系统-计算机毕业设计源码74795

目录 摘要 1 绪论 1.1 选题背景与意义 1.2国内外研究现状 1.3论文结构与章节安排 2系统分析 2.1 可行性分析 2.2 系统流程分析 2.2.1系统开发流程 2.2.2 用户登录流程 2.2.3 系统操作流程 2.2.4 添加信息流程 2.2.5 修改信息流程 2.2.6 删除信息流程 2.3 系统功能…

javascript:判断输入值是数字还是字母

1 代码示例 要判断输入值是数字还是字母&#xff0c;我们可以通过JavaScript获取输入框的值&#xff0c;然后使用isNaN函数来检查输入值是否为数字。 <!DOCTYPE html> <html><head><meta charset"UTF-8"><title></title><s…

第一阶段面试问题(后半部分)

1. c语言中const *p的用法 &#xff08;1&#xff09;const int *p; 或 int const *p; 指向常量整数的指针&#xff0c;通过这个指针不能修改它所指向的整数值&#xff0c;但可以修改指针本身来指向其他地址 const int a 10; const int *p &a; // *p 20; // 错误&…

商家拒单业务

文章目录 概要整体架构流程技术细节小结 概要 商家拒单是电子商务、外卖平台、在线零售等多个行业中可能出现的情况&#xff0c;指的是商家拒绝接受或完成某个订单。这种情况的发生可能由多种原因引起&#xff0c;同时也涉及到商家、平台和消费者的利益平衡。 需求分析以及接…

CTFHUB-XSS-反射型

开启题目&#xff0c;页面如下 先输入以下语句测试一下&#xff0c;发现页面弹出窗口显示“flag”&#xff0c;说明这里存在 XSS 漏洞 <script>alert("flag")</script> 验证存在 XSS 漏洞后&#xff0c;使用 document.cookie 语句在弹窗和控制台中输出当…

DOM案例

一.什么是DOM DOM(Document Object Model)文档对象模型的树形结构 说白了就是用js操作网页 使用方法: 1.找到对象 2.操作 操作网页 节点属性 改变网页内容.... 文档对象模型就是一个树形结构&#xff0c;类似于家谱树 html标签里面包裹了所有的文档内容。他是一个**父亲节…

用了组合式 (Composition) API 后代码变得更乱了,怎么办?

前言 组合式 (Composition) API 的一大特点是“非常灵活”&#xff0c;但也因为非常灵活&#xff0c;每个开发都有自己的想法。加上项目的持续迭代导致我们的代码变得愈发混乱&#xff0c;最终到达无法维护的地步。本文是我这几年使用组合式API的一些经验总结&#xff0c;希望…

【从相邻元素对还原数组】python刷题记录

R3-图篇 饭前一道题 思路&#xff1a; 单向构造 class Solution:def restoreArray(self, adjacentPairs: List[List[int]]) -> List[int]:mnlen(adjacentPairs)#n表示数组元素总数n1#统计dictdefaultdict(int)#存储关系哈希表hashmapdefaultdict(list)for a,b in adjacent…

DeDeCMS漏洞

一.登陆后台 二.文件管理上传shell 我们写一个一句话木马 然后上传 访问他 然后复制网址用工具连接 连接成功 修改模板文件拿shell 找到index.html修改 保存 然后进行下面的操作 访问返回的地址 然后用工具连接 三、后台任意命令执行拿shell 然后写入一个木马 添加成功 点击代…

开源:LLMCompiler高性能工具调用框架

开源&#xff1a;LLMCompiler高性能工具调用框架 LLMCompilerLLMCompiler 框架图任务提取单元使用方式参考链接 LLMCompiler LLMCompiler 是一种 Agent 架构&#xff0c;旨在通过在DAG中快速执行任务来加快 Agent 任务的执行速度。它还通过减少对 LLM 的调用次数来节省 Tokens …

51 华三路由

PC4 路由 能通的区域 MSR2

Vue和React谁更牛逼?看了你就有答案

你好同学&#xff0c;我是沐爸&#xff0c;欢迎点赞、收藏和关注&#xff01;个人知乎、公众号"沐爸空间" 使用 Chrome 浏览器&#xff0c;安装 Vue.js Devtools 和 React Developer Tools 浏览器插件后&#xff0c;打开网站即可知晓当前网站是使用的 Vue 框架还是 …

JCの技巧

当你们私下有矛盾&#xff0c;&#xff08;或者你被J惨了&#xff09;,可以试试以下方法 1.拔电线 优点&#xff1a;快准狠 缺点&#xff1a;看看你身后 2.定时关机 优点&#xff1a;猝不及防 缺点&#xff1a;设置时容易翻车 3.改代码 优点&#xff1a;长代码看不出来…

【数据结构入门 】队列

目录 前言 一、队列的概念及结构 1.概念 2.结构 二、队列的实现 1.队列的声明 2.初始化队列 3.队列的销毁 4.入队 5.出队 6.获取队列有效元素个数 7. 判断队列是否为空 8.获取队首元素 9.获取队尾元素 结论 前言 队列是一种数据结构&#xff0c;它遵循先进先出&#…

数字与位操作——168、670、233、357、400

168. Excel表列名称&#xff08;简单&#xff09; 给你一个整数 columnNumber &#xff0c;返回它在 Excel 表中相对应的列名称。 例如&#xff1a; A -> 1 B -> 2 C -> 3 ... Z -> 26 AA -> 27 AB -> 28 ...示例 1&#xff1a; 输入&#xff1a;columnNumb…

[NISACTF 2022]ezstack-入土为安的第十四天

签到题吧 checksec pwn 没有保护 进入main函数&#xff0c;点进shell &#xff0c;buf 88808048buf system 08048512 /bin/sh 0804A024 直接让代码溢出调用system和/bin/sh from pwn import *# 连接到远程服务 p remote(node5.anna.nssctf.cn, 20789)# 构造 payload payl…