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,应该能过

吐槽:

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

最后祝愿大伙都拿高分。

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

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

相关文章

stm32中的中断优先级

在工作中使用到多个定时器中断,由于中断的中断优先级不熟悉导致出错,下面来写一下中断的一些注意事项。 一、中断的分类 1、EXTI外部中断:由外部设备或外部信号引发,例如按键按下、外部传感器信号变化等。外部中断用于响应外部事件,并及时处理相关任务。 2、内部中断:…

Matlab对多个输入信号进行数值排序提取特定值

1、将多个信号转为一个数组信号输出&#xff0c;在这里需要注意&#xff0c;数据类型是否统一&#xff1b; 2、使用Sort模块&#xff0c;进行排序&#xff08;可设置排序方向&#xff09;&#xff0c;得到排序后的新数组以及对应的索引号&#xff1b; 3、设置想要的索引号&…

常见算法(二分,分块查找,插入,快速排序)

常见算法 1. 顺序查找 package com.mohuanan.exercise;import java.util.ArrayList;public class BasicFind01 {public static void main(String[] args) {int[] arr {1, 2, 3, 1, 2, 3, 4, 5, 6};int number 2;ArrayList<Integer> indexList findIndex(arr, number…

12.事件参数

事件参数 事件参数可以获取event对象和通过事件传递数据 获取event对象 <template><button click"addCount">Add</button><p>Count is: {{ count }}</p> </template> <script> export default {data() {return {count:0…

6.SpringBoot 日志文件

文章目录 1.日志概述2.日志作用3.使用和观察日志3.1如何观察日志3.2使用日志3.3日志级别3.4日志持久化3.5日志分割 4.日志框架4.1门面模式(外观模式)4.2 SLF4J框架介绍4.3 日志格式的说明4.3.1日志名称 5.日志颜色设置6.总结 大家好&#xff0c;我是晓星航。今天为大家带来的是…

Mac下 allure的下载与配置

前提 电脑安装了jdk1.8 链接&#xff1a;mac下配置JDK环境 下载Allure 1.Allure下载最新版本&#xff1a;Releases allure-framework/allure2 GitHub 2.下载后直接解压就好啦 配置 1.根据电脑终端类型输入对应命令&#xff1a; # bash终端 vim ~/.bash_profile # zsh终…

SpringMvc的核心组件和执行流程

一、 springmvc的核心组件及作用 1.DispatcherServlet:前置控制器&#xff0c;是整个流程控制的核心&#xff0c;用来控制其他组件的执行&#xff0c;降低了其他组件的耦合性 2.Handler:控制器&#xff0c;完成具体的业务逻辑&#xff0c;当DispatcherServlet接收到请求后&am…

Pages by User Role for WordPress:强化内容访问控制的必备插件

在数字化时代&#xff0c;WordPress已成为众多网站开发者和设计师的首选平台。然而&#xff0c;如何根据用户角色精确控制内容的访问权限&#xff0c;一直是困扰他们的难题。Pages by User Role for WordPress插件应运而生&#xff0c;为这一难题提供了完美的解决方案。 Pages …

力扣HOT100 - 23. 合并K个升序链表

解题思路&#xff1a; 只要会合并两个升序链表&#xff0c;合并K个做法类似。 class Solution {public ListNode mergeKLists(ListNode[] lists) {ListNode res null;for (int i 0; i < lists.length; i) {res merge(res, lists[i]);}return res;}public ListNode merg…

使用动画做一个走马灯的案例

走马灯 1.第一步-搭建环境 先搭建父盒子。父盒子里面再放入一个子盒子用来装7张图片&#xff0c;有因为图片在一行上了&#xff0c;所以需要使用flex布局。 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><me…

LRU算法介绍,LRU算法是什么

左手编程&#xff0c;右手年华。大家好&#xff0c;我是一点&#xff0c;关注我&#xff0c;带你走入编程的世界。 公众号&#xff1a;一点sir&#xff0c;关注领取编程资料 LRU算法简介 LRU&#xff08;Least Recently Used&#xff09;算法是一种常用的缓存替换策略&#xf…

【人工智能基础】知识表示和专家系统

目录 一、知识 知识 产生式表示法 产生式表示形式 确定的事实性知识的产生式表示 不确定的事实性知识的产生式表示 确定的规则知识的产生式表示 不确定的规则知识的产生式表示 产生式系统构成 优点 缺点 语义网络 优点 缺点 框架 框架的一般结构 框架的继承 优…

golang本地缓存库之bigcache

1. 前言 上周工作之余逛github看到一个本地缓存库bigcache&#xff0c;这个是allegro公司开源的一个项目&#xff0c;主要是用于本地缓存使用&#xff0c;根据他们的博客说明&#xff0c;他们编写这个库最初的目的就是实现一个非常快速的缓存服务。 看了下bigcache这个库的源…

【信号与系统 - 10】拉普拉斯变换

1 定义 周期信号的傅里叶变换那篇提到了&#xff1a; F ( j w ) ∫ − ∞ ∞ e − j w t f ( t ) d t F(jw)\int^{\infty}_{-\infty}e^{-jwt}f(t)dt F(jw)∫−∞∞​e−jwtf(t)dt 这个定义式需要满足绝对可积&#xff0c;即 ∫ − ∞ ∞ ∣ f ( t ) ∣ d t < ∞ \int…

ant design vue + jeecgboot 实现本地上传视频及播放视频功能

文章目录 上传视频1. 上传按钮事件2. 上传按钮触发3. 声明变量visible_uploadVideov4. 上传视频弹窗5. 保存视频6. 关闭上传视频弹窗 播放视频1. 获取上传后的视频1.1 插槽2. 触发播放视频事件3. 播放视频弹窗4. 暂停视频 上传视频 1. 上传按钮事件 点击上传按钮事件 --这个地…

linux进阶篇:使用Apache搭建文件服务器目录

Linux服务搭建篇&#xff1a;使用Apache搭建文件服务器目录 一、关于文件服务器 ​ 在一个项目中&#xff0c;如果想把公共软件或者资料共享给项目组成员&#xff0c;可以搭建一个简易的文件服务器来实现&#xff0c;只要是在局域网内的成员都可以通过浏览器或者wget命令来下…

IDEA中添加servlet模板

官方代码链接 #if (${PACKAGE_NAME} && ${PACKAGE_NAME} != "")package ${PACKAGE_NAME};#end #parse("File Header.java")import javax.servlet.*; import javax.servlet.http.*;

C++奇迹之旅:构造函数和析构函数

文章目录 &#x1f4dd;类的6个默认成员函数&#x1f320; 构造函数&#x1f309; 概念&#x1f309;特性&#x1f309;三种默认构造函数 &#x1f320; 析构函数&#x1f320; 特性&#x1f6a9;总结 &#x1f4dd;类的6个默认成员函数 如果一个类中什么成员都没有&#xff0…

iOS重签名-超详细,附排错

文章目录 重签名步骤步骤 1: 准备必要的材料步骤 2: 解压 .ipa 文件步骤3:将 Provisioning Profile 复制到 Payload 目录步骤 4: 移除原来的签名步骤 5: 使用新的证书和 Provisioning Profile 进行重签名步骤 6: 重新打包 .ipa 文件步骤 7: 安装和测试得到provisioning file和…

Python编程玩转二维码

文章目录 Python编程玩转二维码第一部分&#xff1a;背景介绍第二部分&#xff1a;qrcode库是什么&#xff1f;第三部分&#xff1a;如何安装这个库&#xff1f;第四部分&#xff1a;库函数使用方法第五部分&#xff1a;场景应用第六部分&#xff1a;常见Bug及解决方案第七部分…