2024年第十五届蓝桥杯省赛C++B组(浙江省第二次,4月21号)【真题解析】

本文主要是介绍2024年第十五届蓝桥杯省赛C++B组(浙江省第二次,4月21号)【真题解析】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

等C语言网或者别的地方更新题目,蓝桥杯真题 - 编程题库 - C语言网 (dotcpp.com),后序再做更新

题目没带出来有点忘了,下面是不按顺序来的

第一题:一个数被表达成别的数,是否会出现字母。

除进制取余,进制转换暴力一下,看看哪个进制没有>10的出现

应该是:32

第二题:逆序对期望n=51

1 2 3 4 5 .... 51,任意选择 i 和 j,i≠j,交换。

随机执行两次交换,逆序对的数量期望是几个。

可以枚举所有交换,然后再暴力比较有几个逆序对(不需要归并,n*n也不是很慢,反正是填空题),就能求出总方案。

在概率论和统计学中,数学期望(mathematic expectation [4])(或均值,亦简称期望)是试验中每次可能结果的概率乘以其结果的总和,是最基本的数学特征之一。它反映随机变量平均取值的大小。

所以应该只需要总逆序对求和,除以枚举的次数就行。答案忘了

第三题:传送门

对于序列c[i],代表 i 传送门可以传向 c[i] 传送门

可以执行一次魔法:从i传送门到 i-1传送门 或者 i+1传送门

问最多可以走过几个不同的传送门。

应该就是一个并查集,所有的传送门块分到一起,然后遍历一次应用一下魔法,标记出块与块之间的连通性。

最后枚举所有块本身和块+块是否能使用魔法,累计答案。

第四题:字符串

给你n个字符串,你可以执行一次操作:修改其中的一个字符串中的一个字符。

问任意两对串最长公共前缀的和是多少,如s1="abc",s2="abd",这俩的公共前缀长度是2

不超过200个字符串,长度也不超过200

不会,直接暴力的。

考虑枚举每个字符串的每个位置,并且只枚举n个字符串中出现过的字符。

求一次和复杂度:4e4

枚举每个位置:4e4

总复杂度16e8,爆了,应该要优化。

考虑任意一个字符串,如果前面的某一个位置改变之后,不能带来更好的答案,那么改当前这个字符串的这个位置的更后面,也不会有更优解。这样优化之后可能刚好通过题目。

第五题:字符串

遗迹键盘

比如有以下字符串

S="abc"

T="abcabcbb"

S是你的键盘,T是你要输出的内容。

刚开始你可以选择S的任意一个位置,然后执行操作:左右移动你的位置,或者输出。

总的移动距离超过 L ,你最多可以输出几位内容。

不会,暴力的 :)

考虑你的键盘可能会重复出现按钮,所以搜索的时候相同的都要搜  :(,直接 TLE 飞出去。

因为能重复搜索,也和之前的记忆有关,所以这道题大概率是个dp,本蒟蒻不会。

第六题:狡兔K窟

地上有5000个出入口,地下也有5000个洞窟(最多),每个出入口对应某个洞窟。

即一个洞窟可能有多个出入口。

问,从出入口 S,到出入口 T,地上最短距离是多少(地上出入口连边的长度都是 1)。

如果 S 和 T 连着同一个洞窟,那么显然走地下就行了,地上距离是 0。

因为地上边的长度都是 1,所以求最短路使用 BFS,BFS一次复杂度 5e3,5e3个出入口,总复杂度25e6,就可以求出任意两个出入口之间的最短路。

因为考虑到可以走洞窟,那么把入口之间的最短路在每次BFS的时候转化成洞窟之间的最短路。

最后访问做到O(1),应该恰好通过此题。

Dijkstra或者别的最短路算法,复杂度会比BFS多一个log。(技巧:边都相等,或者都相等和边长为0的,使用BFS就能求出最短路)

第七题:题目忘了

题目大意是任意选择 l 和 r(l<=r),要求 a[l],a[r] 均大于 a[l-1 ~ r-1] 他们中间的值,求最大的 r-l+1

当时题目分析错了,还以为左边降序右边升序,实际上内部无序也行,只要满足条件。

n^3:考虑暴力枚举左右端点,暴力枚举端点中间的最大值,判断是否可行。

n^2*logn:考虑暴力枚举左右端点,内部区间最大值用线段树来维护。

n^2:没想到,可能还要加个二分。

第八题:素数

对于 i mod k = 0 的 a序列中的值,将他替换成比他大x的质数,或者比他小x的质数。

这里是下标 i 啊,有好多人以为是 a[i] mod k,不是具体的值。

如果最后替换完了之后,质数小于0,那就把它变成0,如果大于10w,就变成1(好像是10w)

首先我们分类讨论一下,质数和非质数的变换是否有区别:

3,先变成比他大2次的质数,再变成比他小一次的质数,->5->7->5

4,->5->7->5

可以发现是没有区别的,可以直接进行模拟。

这里需要注意的是不需要每次访问就直接替换,可以先把替换到哪里累加下来,比如大三次,小一次,那就是大两次。

最后用埃式筛预处理10w以内的所有素数,如果最后的变换超过了10w的范围,或者变成负数,直接变成0或者1就可以了。

因为素数筛出来是有序的,可以二分先找到 第一个大于 a[i]的素数,然后下标加上 最后累计的次数(注意判断范围,要减一),就是目标结果,负数也一样,注意最后累加值是负数,最后不是减一是加一。

总复杂度nlogn,应该能过

吐槽:

代码能力要求有点高,但凡看错一个细节可能就没分了,甚至还没直接暴力拿的分高。

最后祝愿大伙都拿高分。

这篇关于2024年第十五届蓝桥杯省赛C++B组(浙江省第二次,4月21号)【真题解析】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/925588

相关文章

关于C++中的虚拟继承的一些总结(虚拟继承,覆盖,派生,隐藏)

1.为什么要引入虚拟继承 虚拟继承是多重继承中特有的概念。虚拟基类是为解决多重继承而出现的。如:类D继承自类B1、B2,而类B1、B2都继承自类A,因此在类D中两次出现类A中的变量和函数。为了节省内存空间,可以将B1、B2对A的继承定义为虚拟继承,而A就成了虚拟基类。实现的代码如下: class A class B1:public virtual A; class B2:pu

C++对象布局及多态实现探索之内存布局(整理的很多链接)

本文通过观察对象的内存布局,跟踪函数调用的汇编代码。分析了C++对象内存的布局情况,虚函数的执行方式,以及虚继承,等等 文章链接:http://dev.yesky.com/254/2191254.shtml      论C/C++函数间动态内存的传递 (2005-07-30)   当你涉及到C/C++的核心编程的时候,你会无止境地与内存管理打交道。 文章链接:http://dev.yesky

C++的模板(八):子系统

平常所见的大部分模板代码,模板所传的参数类型,到了模板里面,或实例化为对象,或嵌入模板内部结构中,或在模板内又派生了子类。不管怎样,最终他们在模板内,直接或间接,都实例化成对象了。 但这不是唯一的用法。试想一下。如果在模板内限制调用参数类型的构造函数会发生什么?参数类的对象在模板内无法构造。他们只能从模板的成员函数传入。模板不保存这些对象或者只保存他们的指针。因为构造函数被分离,这些指针在模板外

C++工程编译链接错误汇总VisualStudio

目录 一些小的知识点 make工具 可以使用windows下的事件查看器崩溃的地方 dumpbin工具查看dll是32位还是64位的 _MSC_VER .cc 和.cpp 【VC++目录中的包含目录】 vs 【C/C++常规中的附加包含目录】——头文件所在目录如何怎么添加,添加了以后搜索头文件就会到这些个路径下搜索了 include<> 和 include"" WinMain 和

解析 XML 和 INI

XML 1.TinyXML库 TinyXML是一个C++的XML解析库  使用介绍: https://www.cnblogs.com/mythou/archive/2011/11/27/2265169.html    使用的时候,只要把 tinyxml.h、tinystr.h、tinystr.cpp、tinyxml.cpp、tinyxmlerror.cpp、tinyxmlparser.

C/C++的编译和链接过程

目录 从源文件生成可执行文件(书中第2章) 1.Preprocessing预处理——预处理器cpp 2.Compilation编译——编译器cll ps:vs中优化选项设置 3.Assembly汇编——汇编器as ps:vs中汇编输出文件设置 4.Linking链接——链接器ld 符号 模块,库 链接过程——链接器 链接过程 1.简单链接的例子 2.链接过程 3.地址和

C++必修:模版的入门到实践

✨✨ 欢迎大家来到贝蒂大讲堂✨✨ 🎈🎈养成好习惯,先赞后看哦~🎈🎈 所属专栏:C++学习 贝蒂的主页:Betty’s blog 1. 泛型编程 首先让我们来思考一个问题,如何实现一个交换函数? void swap(int& x, int& y){int tmp = x;x = y;y = tmp;} 相信大家很快就能写出上面这段代码,但是如果要求这个交换函数支持字符型

21.手绘Spring IOC运行时序图

1.再谈IOC与 DI IOC(lnversion of Control)控制反转:所谓控制反转,就是把原先我们代码里面需要实现的对象创 建、依赖的代码,反转给容器来帮忙实现。那么必然的我们需要创建一个容器,同时需要一种描述来让 容器知道需要创建的对象与对象的关系。这个描述最具体表现就是我们所看到的配置文件。 DI(Dependency Injection)依赖注入:就是指对象是被动接受依赖类

创新、引领、发展——SAMPE中国2024年会在京盛大开幕

绿树阴浓夏日长,在这个色彩缤纷的季节,SAMPE中国2024年会暨第十九届国际先进复合材料制品原材料、工装及工程应用展览会在中国国际展览中心(北京朝阳馆)隆重开幕。新老朋友共聚一堂,把酒话桑麻。 为期4天的国际学术会议以“先进复合材料,引领产业创新与可持续化发展”为主题,设立了34个主题分会场,其中包括了可持续化会场、国际大学生会场、中法复合材料制造技术峰会三个国际会场和女科技工作者委员会沙龙,

C++入门01

1、.h和.cpp 源文件 (.cpp)源文件是C++程序的实际实现代码文件,其中包含了具体的函数和类的定义、实现以及其他相关的代码。主要特点如下:实现代码: 源文件中包含了函数、类的具体实现代码,用于实现程序的功能。编译单元: 源文件通常是一个编译单元,即单独编译的基本单位。每个源文件都会经过编译器的处理,生成对应的目标文件。包含头文件: 源文件可以通过#include指令引入头文件,以使