当前位置: 首页 > news >正文

【蓝桥杯】第15届蓝桥杯青少组stema选拔赛C++中高级真题答案(20240310)

在这里插入图片描述

一、选择题

第 1 题

在这里插入图片描述

第 2 题

表达式1000/3的结果是( A )。
A.333
B.333.3
C.334
D.333.0

第 3 题

下列选项中,判断a等于1并且b等于1正确的表达式是( B )。
A.!((a!=1)&&(b!=1))
B.!((a!=1)||(b!=1))
C.!(a==1)&&(b==1)
D.(a=1)&&(b=1)
【解析】
A选项 !((a!=1)&&(b!=1)) ,意思是“取反(a不等于1且b不等于1)”,也就意味只要a和b中一个为1,结果就为真,显然这样不行。

B选项 !((a!=1)||(b!=1)) ,意思是“对(只要a或b其中一个不等于1以及a和b都不为1就为真的结果)取反”即为假,也就意味着“a和b都等于1”为真,这个符合要求,因此是正确答案。

C选项 !(a==1)&&(b==1) ,意思是“要求a不为1时且b为1时”为真,明显不符合。

D选项 (a=1)&&(b=1) ,注意这里是赋值运算符“=”而不是比较是否相等的运算符“==”,因此意思就成了“将a赋值为1 且 将b赋值为1”,不管a和b原来初始化为什么或者输入什么统统赋值为1,“&&”两边都是1,也就是都为真,这就成了“啊对对对”,错误。

第 4 题

定义 char a[]=“His name is Jack”,请问 sizeof(a)的结果是( D )。
A.14
B.15
C.16
D.17
【解析】
char a[]=“His name is Jack”,建立一个字符数组a,使用"His name is Jack"这个字符串给a进行初始化,要将字符串中的字符存入字符数组,就必然在末尾带上了一个字符串结束符‘\0’,所以除了"His name is Jack"这里面的16个字符外,还在末尾存入了一个字符串结束符‘\0’,所以是17个字符。

第 5 题

定义 int a[]={5,1,3,8,2,9,0,6},*p=(a+3),那么((*p)-- + *p )的值是( C )。
A.3
B.10
C.15
D.16
【解析】
((*p)-- + *p )执行的过程:【1】首先是(p)–先给出一个p,将里面的值8输出;【2】还是(p)–这里的–,将p指针指向位置的数据-1,现在p值改为7了;【3】+ p这里再取一次p值。因此表达式就成了这样:8 + 7 ,所以答案是15,选择C。

二、编程题

第 1 题

编程实现:寒假期间小明需要做完n张试卷,但他每天最多能做完m 张,请计算出小明做完n张试卷最少需要多少天?
【输入描述】
一行输入两个整数n和m(1≤n≤100,1≤m≤10),分别表示要完成的试卷张数,及每天最多能做完的试卷张数,整数之间以一个空格隔开
【输出描述】
输出一个整数,表示小明最少多少天能做完n张试卷
【样例输入】
10 3
【样例输出】
4

// 方法1:
#include<bits/stdc++.h>
using namespace std;
int main(){int n,m;cin>>n>>m;cout<<n/m+(n%m!=0);return 0;
}// 方法2:
#include<bits/stdc++.h>
using namespace std;
int main(){int n,m;cin>>n>>m;cout<<(n+m-1)/m;return 0;
}// 方法3:
#include<bits/stdc++.h>
using namespace std;
int main(){int n,m;int ans;cin>>n>>m;ans=n/m;if (n%m!=0){ans++;}cout<<ans;return 0;
}// 方法4:
#include<bits/stdc++.h>
using namespace std;
int main(){int n,m;int ans;cin>>n>>m;cout<<int(ceil(1.0*n/m));return 0;
}

第 2 题

编程实现:给定两个整数a,b,请统计a到b之间(包含a和b)有多少个包含数字7的回文数。
例如:a=6,b=80,6到80之间的回文数有6、7、8、 9、11、22、33、44、55、66、77,其中有2个回文数包含7(7和77)。
【输入描述】
一行输入两个整数a和b(1≤a≤b≤100000),整数之间以一个空格隔开
【输出描述】
输出一个整数,表示a到b之间(包含a和b)包含数字7的回文数的个数
【样例输入】
680
【样例输出】
2

#include<bits/stdc++.h>
using namespace std;
int huiwen(int n){//判断是否回文int a=n,b=0;while(n){b=b*10+n%10;n/=10;}return b==a;
}
int check(int n){//判断是否含7while(n){if(n%10==7) return 1 ;n/=10;}return 0;
}
int main(){int a,b,cnt=0;cin>>a>>b;for(int i=a;i<=b;i++){if(huiwen(i) && check(i)) cnt++;}cout<<cnt;return 0;
}

第 3 题

编程实现:给定一个字符串S,请统计S中有多少个ABB形式的子串, 以及多少种ABB形式的子串。
例如:S=“nnnseebbetoosee”,ABB形式的子串有see、 ebb、too、see,共4个;不同子串有see、ebb、too,共3种。
【输入描述】
输入一个长度不超过100的字符串S
【输出描述】
输出两个整数,分别表示S中有多少个ABB形式的子串,以及多少种ABB形式的子串,整数之间以一个空格隔开
【样例输入】
nnnseebbetoosee
【样例输出】
4 3

提示信息:
ABB形式的字符串:是由3个字符组成,其中后两个字符相同,第一个字符与后两个字符不同。如:“cbb”、“q22”、"688"都是 ABB 形式的字符串;“abc”、“wwe”、"pop"都不是 ABB 形式的字符串。子串:是指一个字符串中连续的一段字符序列。如:字符串“Hello,World!"中,“Hello”、“ello”、“World”、"or"都是该字符串的子串。

#include<bits/stdc++.h>
using namespace std;
set <string> s;
int main() {int cnt = 0;string a;cin >> a;if(a.size() < 3) {cout << "0 0";return 0;}for(int i = 0; i < a.size() - 2; i++) {string b = a.substr(i, 3);if(b[0] != b[1] && b[1] == b[2]) {cnt++;s.insert(b);}}cout << cnt << " " << s.size();return 0;
}

第 4 题

编程实现:给定一个由n个整数组成的数列,请将其分割成左右两部分, 要求左半部分子数列的和与右半部分子数列的和最接近,请输出这两部分子数列和的差值(取非负值)。
例如:n=5,数列中的5个整数分别是2、1、3、4、3,将其分割成左右两部分,左半部分是2、1、3,右半部分是4、 3;此时两部分子数列的和最接近,差值为1。
【输入描述】
第一行输入一个整数n(2≤n≤100000)
第二行输入n个整数(1≤整数≤1000),整数之间以一个空格隔开
【输出描述】
输出一个整数,表示这两部分子数列和的差值(取非负值)
【样例输入】
5
2 1 3 4 3
【样例输出】
1

// 方法1:
#include <bits/stdc++.h>
using namespace std;
int n;
int a[100005];
int main() {cin >> n;for (int i = 1; i <= n; i++) {cin>>a[i];}int sum1=0;int sum2=0;int i=1;int j=n;while(i<=j){if (sum1<sum2){sum1+=a[i];i++;}else{sum2+=a[j];j--;}}cout<<abs(sum1-sum2);return 0;
}// 方法2:
#include<bits/stdc++.h>
using namespace std;
int n,a,s[100005],minn=2e9;
int main(){cin>>n;for (int i=1;i<=n;i++) cin>>a,s[i]=s[i-1]+a;for (int i=1;i<n;i++){minn=min(abs((s[i]-s[0])-(s[n]-s[i])),minn);}cout<<minn<<endl;return 0;
}// 方法3:
#include<bits/stdc++.h>
using namespace std;
int n,a[1000005],sum=0,m=1e9,sum1=0;
int main(){cin>>n;for(int i=1;i<=n;i++){cin>>a[i];sum+=a[i];}for(int i=1;i<=n;i++){sum1+=a[i];sum-=a[i];m=min(abs(sum1-sum),m);}cout<<m;return 0;
}

第 5 题

编程实现:给定一个正整数n,请将n中的每位数字重新排列并组成一个新数,要求新数的值要小于n,请找出所有符合要求的新数中最大的那个正整数,如果不存在这样的正整数,则输出-1。
例1:n=312,312中每位上的数字依次是3、1、2,重新排列组成的新数有321、231、213、132、123,新数中小于312的有231、213、132、123,其中符合要求的最大正整数是231;
例2:n=123,123中每位上的数字依次是1、2、3,重新排列组成的新数有312、321、231、213、132,新数中不存在小于123的正整数,故输出-1。
【输入描述】
输入一个正整数 n (1≤ n <2的63次方)
【输出描述】
输出一个正整数,表示符合要求的最大正整数
【样例输入】
312
【样例输出】
231

// 方法1:(贪心算法)
#include <bits/stdc++.h>
using namespace std;
string a;
int main() {cin >> a;int len=a.length();bool flag=0;//假定无解for(int i=len-1;i>0;i--){if (a[i]<a[i-1]){for(int j=i,k=len-1;j<k;j++,k--){swap(a[j],a[k]);}for(int j=i;j<=len-1;j++){if(a[i-1]>a[j]){swap(a[i-1],a[j]);break;}}flag=1;//有解break;}}if(flag==1&&a[0]!='0'){cout<<a;}else{cout<<-1;}return 0;
}

将n个字符按照任意方式排列,所得到的所有组合,叫做n的全排列。这些全排列从小到大的顺序,叫做这n个数的字典序。对于某一种排列方式,使用c++的stl库提供的prev_permutation可以获得其上一种字典序,也就是紧挨着他的,比他小的那种排列。因此只需要用字符串接受输入,然后获取该字符串的上一个字典序就行了。

// 方法2:(prev_permutation)
#include<bits/stdc++.h> 
using namespace std;
int main() {string n;cin >> n;if (prev_permutation(n.begin(), n.end())&&n[0]!=0)cout << n;elsecout << -1;
}

第 6 题

编程实现:靶场上有n块靶排成一排,从左到右依次编号为1、2、3、….n,且每块靶上都标有一个整数。当某块靶被击中后,击中者会得到 x * y * z 的积分。( y 表示被击中的靶上的数,×表示其左侧最近且未被击中的靶上的数,z表示其右侧最近且未被击中的靶上的数。如果其左侧不存在未被击中的靶,则x为1;如果其右侧不存在未被击中的靶,则z为1。)计算完积分后,这块靶就会退出靶场(不在这排靶中)。请计算击中所有靶后能得到的最高积分是多少?
例如:n=4,表示有4块靶,这4块靶上的数从左到右分别是3、2、4、6;
按照下列顺序打靶,可以得到最高积分:
1.打2号靶,得到的积分是24(324);
2.打3号靶,得到的积分是72(346);
3.打1号靶,得到的积分是18(136);
4.打4号靶,得到的积分是6(161);
最终获得的积分是120(24+72+18+6)。
【输入描述】
第一行输入一个整数n(1≤n≤300),表示靶场上靶的数量
第二行输入n个整数(1≤整数≤100),分别表示从左到右每块靶上的数,整数之间以一个空格隔开
【输出描述】
输出一个整数,表示击中所有靶后能得到的最高积分
【样例输入】
4
3 2 4 6
【样例输出】
120

#include<bits/stdc++.h>
using namespace std;
int n;
int a[305];
int dp[305][305];//打掉ij之间所有靶子可以获得的最大积分(不含i,j)
int main() {cin>>n;for(int i=1;i<=n;i++){cin>>a[i];}a[0]=1;a[n+1]=1;for(int i=n+1;i>=0;i--){for(int j=i+1;j<=n+1;j++){for(int k=i+1;k<j;k++){dp[i][j]=max(dp[i][j],dp[i][k]+dp[k][j]+a[k]*a[i]*a[j]);}}}cout<<dp[0][n+1];return 0;
}

相关文章:

【蓝桥杯】第15届蓝桥杯青少组stema选拔赛C++中高级真题答案(20240310)

一、选择题 第 1 题 第 2 题 表达式1000/3的结果是( A )。 A.333 B.333.3 C.334 D.333.0 第 3 题 下列选项中&#xff0c;判断a等于1并且b等于1正确的表达式是( B )。 A.!((a!1)&&(b!1)) B.!((a!1)||(b!1)) C.!(a1)&&(b1) D.(a1)&&(b1) 【解析】 A…...

20240319金融读报:金融助力农业科创企业风控模型

1、农发行2023年第二十期金融债券票面利率为2.85% 2、农业生产现代化转型-》农机&#xff1a;新疆尉犁县超级棉田里&#xff0c;农业无人机、采棉打包机、棉田打顶机器人等现代化机械设施&#xff0c;让两个人收种3000亩棉田成为了可能&#xff08;金融机构可以结合农机购置补贴…...

React.js快速入门教程

React.js 是一个流行的 JavaScript 库&#xff0c;用于构建用户界面。以下是一个简单的 React.js 快速入门教程&#xff1a; 步骤 1&#xff1a;安装 Node.js 和 npm 首先&#xff0c;确保你的计算机上安装了 Node.js 和 npm&#xff08;Node 包管理器&#xff09;。你可以从…...

Jenkins构建时报错:Build step ‘Execute shell‘ marked build as failure

1.磁盘空间不足导致报错。 2.默认情况下&#xff0c;Jenkins采取 /bin/sh -xe 这种方式 -x 将打印每一个命令&#xff1b;另一个选项 -e&#xff0c;当任何命令以非零值&#xff08;当任何命令失败时&#xff09;退出代码时&#xff0c;这会导致shell立即停止运行脚本。 解决…...

C语言复杂度(个人笔记)

时间复杂度主要衡量一个算法的运行快慢. 空间复杂度主要衡量一个算法运行所需要的额外空间. 时间复杂度 算法中的基本操作的执行次数&#xff0c;为算法的时间复杂度. 只需要大概执行次数&#xff0c;我们使用大O的渐进表示法。(看谁对数学表达式的影响最大) 空间复杂度 是…...

与AI机器共存的三个层次

概述 当前我们无法不与AI机器共存。 或者说&#xff0c;在不远的近日&#xff0c;不能与AI机器和谐共处的人&#xff0c;就有可能会被淘汰。 新的生产革命&#xff0c;或许已经到来&#xff0c;只是我们身在此山中&#xff0c;当局者迷而已。 三个层次 API(Application Pr…...

python网络爬虫实战教学——requests的使用(1)

文章目录 专栏导读1、前言2、get请求3、抓取网页4、抓取二进制数据5、请求头 专栏导读 ✍ 作者简介&#xff1a;i阿极&#xff0c;CSDN 数据分析领域优质创作者&#xff0c;专注于分享python数据分析领域知识。 ✍ 本文录入于《python网络爬虫实战教学》&#xff0c;本专栏针对…...

腾讯云COS - 前端上传文件到 COS 跨域问题

问题描述 原因分析 因为我本地的地址是&#xff1a;http://localhost:9528 而发送请求时的地址是&#xff1a;http://132-1307119153.cos.ap-beijing.myqcloud.com/tu.jpg 域名不同&#xff0c;自然而然就出现了跨域的问题&#xff01; 解决方案 先点击对象存储 - 安全设置…...

【笔记】Python学习记录

Python学习记录 Hello World变量简单数据类型字符串大小写转换插入变量Tab和Enter删除前后空格删除前后缀 Hello World 老调调了&#xff0c;如何在终端输出信息呢&#xff1f; print("Hello World")Hello World变量 变量命名遵从代码变量命名通则&#xff0c;几乎…...

力扣每日一题 2024/3/21 频率跟踪器

题目描述 用例说明 思路讲解 看到统计数字频率或者出现次数很容易想到用哈希表&#xff0c;但是一个哈希表count将数字和数字出现次数映射起来似乎不太够&#xff0c;如果需要统计数字出现次数的频率的话还是需要进行一次遍历&#xff0c;时间复杂度为O(n)&#xff0c;有没有常…...

基于SpringBoot 实现指标监控及日志管理

添加Actuator功能 Spring Boot Actuator可以帮助程序员监控和管理SpringBoot应用&#xff0c;比如健康检查、内存使用情况统计、线程使用情况统计等。我们在SpringBoot项目中添加Actuator功能&#xff0c;即可使用Actuator监控 项目&#xff0c;用法如下&#xff1a; 在被监…...

Linux之看门狗

1、什么是看门狗&#xff1f; 在Linux系统中&#xff0c;看门狗机制主要包括硬件看门狗、软件看门狗和看门狗守护进程三个部分。硬件看门狗是一个独立的计时器设备&#xff0c;用于监视系统的运行状态。如果系统长时间没有发送喂狗信号&#xff0c;硬件看门狗将执行预设的动作…...

第十九章 TypeScript 装饰器Decorator

Decorator 装饰器是一项实验性特性&#xff0c;在未来的版本中可能会发生改变 它们不仅增加了代码的可读性&#xff0c;清晰地表达了意图&#xff0c;而且提供一种方便的手段&#xff0c;增加或修改类的功能 若要启用实验性的装饰器特性&#xff0c;你必须在命令行或tsconfig…...

第十四章 TypeScript tsconfig.json配置文件

生成tsconfig.json 文件 这个文件是通过tsc --init命令生成的 配置详解 "compilerOptions": {"incremental": true, // TS编译器在第一次编译之后会生成一个存储编译信息的文件&#xff0c;第二次编译会在第一次的基础上进行增量编译&#xff0c;可以提…...

科技助力高质量发展:新质生产力的崛起与企业数字化转型

引言 随着科技的飞速发展&#xff0c;我们正逐渐步入数字化智能时代&#xff0c;这个时代不仅为企业带来了无限的机遇&#xff0c;也让其面对前所未有的挑战。在这个快速变革的时代&#xff0c;企业必须不断调整自己的经营策略&#xff0c;适应数字化转型的浪潮&#xff0c;以…...

Redis - 缓存访问 缓存穿透 缓存击穿 缓存雪崩

一、缓存访问 1、客户端发送请求 2、服务首先会请求 redis&#xff0c;查看请求的内容是否存在 3、redis 将请求结果返回给服务&#xff0c;如果返回的结果有数据则直接返回给客户端&#xff1b;如果没有数据则会继续往下执行 4、服务从数据库中查询请求的数据 5、数据库将…...

SAP Business Application Studio(BAS)中开发Fiori App的基础知识

1. SAP Fiori Tools SAP Fiori Tools是一套用于支持SAP Fiori应用开发的工具&#xff0c;包括应用模板、可视化编辑器、代码生成、应用预览和集成测试工具等。这些工具可以帮助开发者更快速、更简单地创建和维护SAP Fiori应用。SAP Fiori Tools 可与SAP的开发环境&#xff08;…...

DashScope - 阿里模型服务灵积

文章目录 关于 DashScope快速上手代码调用http 请求示例Python 调用 关于 DashScope 官方主页&#xff1a;https://dashscope.aliyun.comPYPI : https://pypi.org/project/dashscope/支持模型&#xff1a;https://dashscope.console.aliyun.com/model DashScope灵积模型服务建…...

个人信息-求职[web前端]

我有近近10年开发及6年的管理经验Web前端,所负责的技术团队经历了 Web 前端几代技术变革&#xff0c;参与了几乎&#xff0c;在性能优化、开发效率、所有前端相关项目工程化架构选型上都有丰厚的产出。在上家致力于数据安全前端的相关工作&#xff0c;专注于Vue.js技术栈来推进…...

Apache DolphinScheduler 社区开启讲师招募,赶快加入吧!

随着Apache DolphinScheduler在全球范围内的快速发展&#xff0c;我们的用户群体和社区活动也在不断扩大。 为了进一步丰富我们的社区内容&#xff0c;分享更多有价值的知识和经验&#xff0c;我们诚挚地邀请您加入我们&#xff0c;成为Apache DolphinScheduler社区的分享嘉宾。…...

KubeSphere 容器平台高可用:环境搭建与可视化操作指南

Linux_k8s篇 欢迎来到Linux的世界&#xff0c;看笔记好好学多敲多打&#xff0c;每个人都是大神&#xff01; 题目&#xff1a;KubeSphere 容器平台高可用&#xff1a;环境搭建与可视化操作指南 版本号: 1.0,0 作者: 老王要学习 日期: 2025.06.05 适用环境: Ubuntu22 文档说…...

基于算法竞赛的c++编程(28)结构体的进阶应用

结构体的嵌套与复杂数据组织 在C中&#xff0c;结构体可以嵌套使用&#xff0c;形成更复杂的数据结构。例如&#xff0c;可以通过嵌套结构体描述多层级数据关系&#xff1a; struct Address {string city;string street;int zipCode; };struct Employee {string name;int id;…...

Java 语言特性(面试系列1)

一、面向对象编程 1. 封装&#xff08;Encapsulation&#xff09; 定义&#xff1a;将数据&#xff08;属性&#xff09;和操作数据的方法绑定在一起&#xff0c;通过访问控制符&#xff08;private、protected、public&#xff09;隐藏内部实现细节。示例&#xff1a; public …...

linux 错误码总结

1,错误码的概念与作用 在Linux系统中,错误码是系统调用或库函数在执行失败时返回的特定数值,用于指示具体的错误类型。这些错误码通过全局变量errno来存储和传递,errno由操作系统维护,保存最近一次发生的错误信息。值得注意的是,errno的值在每次系统调用或函数调用失败时…...

Robots.txt 文件

什么是robots.txt&#xff1f; robots.txt 是一个位于网站根目录下的文本文件&#xff08;如&#xff1a;https://example.com/robots.txt&#xff09;&#xff0c;它用于指导网络爬虫&#xff08;如搜索引擎的蜘蛛程序&#xff09;如何抓取该网站的内容。这个文件遵循 Robots…...

鸿蒙中用HarmonyOS SDK应用服务 HarmonyOS5开发一个生活电费的缴纳和查询小程序

一、项目初始化与配置 1. 创建项目 ohpm init harmony/utility-payment-app 2. 配置权限 // module.json5 {"requestPermissions": [{"name": "ohos.permission.INTERNET"},{"name": "ohos.permission.GET_NETWORK_INFO"…...

mysql已经安装,但是通过rpm -q 没有找mysql相关的已安装包

文章目录 现象&#xff1a;mysql已经安装&#xff0c;但是通过rpm -q 没有找mysql相关的已安装包遇到 rpm 命令找不到已经安装的 MySQL 包时&#xff0c;可能是因为以下几个原因&#xff1a;1.MySQL 不是通过 RPM 包安装的2.RPM 数据库损坏3.使用了不同的包名或路径4.使用其他包…...

【碎碎念】宝可梦 Mesh GO : 基于MESH网络的口袋妖怪 宝可梦GO游戏自组网系统

目录 游戏说明《宝可梦 Mesh GO》 —— 局域宝可梦探索Pokmon GO 类游戏核心理念应用场景Mesh 特性 宝可梦玩法融合设计游戏构想要素1. 地图探索&#xff08;基于物理空间 广播范围&#xff09;2. 野生宝可梦生成与广播3. 对战系统4. 道具与通信5. 延伸玩法 安全性设计 技术选…...

OPENCV形态学基础之二腐蚀

一.腐蚀的原理 (图1) 数学表达式&#xff1a;dst(x,y) erode(src(x,y)) min(x,y)src(xx,yy) 腐蚀也是图像形态学的基本功能之一&#xff0c;腐蚀跟膨胀属于反向操作&#xff0c;膨胀是把图像图像变大&#xff0c;而腐蚀就是把图像变小。腐蚀后的图像变小变暗淡。 腐蚀…...

【Go语言基础【13】】函数、闭包、方法

文章目录 零、概述一、函数基础1、函数基础概念2、参数传递机制3、返回值特性3.1. 多返回值3.2. 命名返回值3.3. 错误处理 二、函数类型与高阶函数1. 函数类型定义2. 高阶函数&#xff08;函数作为参数、返回值&#xff09; 三、匿名函数与闭包1. 匿名函数&#xff08;Lambda函…...