2024蓝桥杯国赛C++研究生组游记+个人题解

2024-06-02 01:44

本文主要是介绍2024蓝桥杯国赛C++研究生组游记+个人题解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Day0

开始复习,过了一遍大部分板子

本来打算再学一遍SAM,但是想到去年考了字符串大题今年应该不会再考了吧。。

过了一遍数据结构和图论,就1点了

两点的时候还没睡着,舍友打游戏好像打到2点过。。

Day1

相当困

第一题:

数田字有多少条直线可以只经过两个点,12条

第二题:

求长度42的置换中,周期恰好为2024的置换个数

首先2024=8*11*23,然后8+11+23=42,然后就是组合数C(42,8)*C(34,11)

结果赛后复盘的时候发现不对劲,想简单了,还有环内部的顺序需要计算,应该还要乘上每个环长度的欧拉函数值(?

第三题:

限流器,T条访问记录,每条访问记录有一个时间戳,每n个时间单位作为一个限流区间,每个区间最多能提供m次访问机会。求成功访问的次数。

由于时间给的很小(<=1000),直接除一下n,放桶里,最后和m取min再求和。

第四题:

给一个数组a[i],求把所有数加上x再mod k之后,小于等于t的数最多能有多少个

先对所有a[i] mod一下k,变成求一段长度为t+1的区间最多能够覆盖多少值,由于这个问题是环形的,我们套路地把数组a[i]的每个值加上k的复制一段在后面,转化为区间问题。

贪心一下,我们选取的区间左端点一定是某个a[i]值,否则就可以让区间更靠后,以此获取更多覆盖的区域。

two-pointers扫一遍就可以知道结果了。注意边界条件判断。

当然,数据范围比较温和,二分查找logn也可以过。

此时9:34。

第五题:

小模拟,模拟vim指令编辑字符串,n^3

发现insert是中文引号,很诡异,但是不影响结果

这题写了我一个小时,厉害吧,我是真的唐啊

写完10:24了

第六题:

一个字符串,定义一个合法划分:划分中任意两个相邻的子串不能有公共字符。求该字符串中所有长度为1~5的本质不同的子串,这些子串在任意一个合法划分中都没有出现,请将他们按字典序输出。

首先,合法划分必然存在(怎么有点像绕口令),ababaabb可分为a|b|a|b|aa|bb

考虑一个串能在合法划分中出现,例如abcde,那么他的两端必然没有与a、b、c、d、e这五个字符相同的字符,否则这个子串就不能被划分出来。

于是我们枚举所有长度1~5的串,判断他是否能在合法划分中出现,能的话就给他的哈希值打上一个标记,因为字符串长度只有5,map+long long就可以过。

然后我们第二次,扫描所有长度为1~5的子串,看哈希值是否被标记过,如果没有就加入答案的集合。

最后对答案集合进行排序、去重就结束了。

ps:为什么不直接求不合法的子串,因为一段字符串中,aabaccaba,例如aba实际上是可以在合法划分中出现的,划分为:aa|b|a|cc|aba,但是如果直接求的话,a|aba|cc|a|b|a就发现前面这里的aba实际上不合法。

写完调完直接11:00

第七题:

一个带权有向图n个点(n<=50),给出邻接矩阵,m次查询(m<=1000),查询u点到v点恰好经过c条边的最短路径,并且可以将路径上的一条边边权减半(但是多次经过的话只能减半一次)。

一眼就是倍增floyd,再加上一个求路径max,同样可以倍增做。

不过时间复杂度非常逆天O(m*n^3*logc),考虑怎么优化

发现我不会,70分遗憾离场。

此时11:32,很急,后面还有三道大题没看。

第八题:

给一段序列,它来源于对一棵树的先序遍历的节点深度,已知该序列的一部分(未知的部分用-1

代替),求这个序列一共有多少种可能。

首先发现,先序遍历的深度序列任意一个值都满足a[i]<=a[i-1]+1(i>1)

然后,对于每一段-1,我们都可以对其进行计数。

设f[i][j]为第i位的值为j时,序列1~i构成的方案数

f[i][j]=f[i-1][j-1]+f[i-1][j]+f[i-1][j+1]+……+f[i-1][i-1],即对前一个f[i-1]的一个后缀和,再向后平移一位

假设这一段-1(区间为[l,r])的前一个数为x,后一个数为y,那么设f[l-1][x]=1

最终答案为f[r+1][y]

最后把每段的答案乘起来就是最终答案。

考虑如何优化这个后缀和

发现我不会,30分遗憾离场。

做完之后12:15,顿时觉得可以开摆了。

赛后复盘其实觉得不应该放弃这一点的,毕竟初值只有一个1,后面也只查询一个点,应该是可以用数学公式推出来的。

第九题:

n个点,每两个点i,j之间有一条边,若i*j为完全平方数则边权为1,否则为0。

特殊生成树定义为任意一个点都必定有一条边连接一个比自己权值小的点。

对每个k,求边权为k(k=0~n-1)的特殊生成树有多少个。

首先,这个特殊的性质规定了生成树的产生方式:顺序枚举1~n点,依次加入生成树,并且只能选择1~i-1的其中一个点进行连接。

于是乎,我们维护的n-1个点的答案数组f[i],表示边权为i的生成树有多少个,

在加入点n之后f[i]=cnt*f[i-1]+(n-1-cnt)*f[i],cnt表示n与1~n-1中乘积为完全平方数的个数。

这样就可以n^2拿到60分

至于85分就是分治NTT,模数还正好是998244353,相当于求一下乘积Π(i-1-cnti+cnti*x)的多项式系数。 

最后的100分应该是NTT过程中其实可以优化,因为cnti可能为0,这样可以在常数上小一点,然后n(logn)^2过掉。

只可惜时间不够,但即便是时间够,我也不会写NTT了。。。。

真的很菜欸。。60分遗憾离场了。

至于cnt的求法,先把n分解质因数,对每个质因子次数ai,如果是偶数就凑(0、2、4、……、ai)

如果是奇数就凑(1、3、5、……、ai),也就是(ai+1)/2种凑法。然后把每个质因子凑法乘起来再-1(减掉本身)就是cnt了。复杂度O(n*sqrt(n))

如果不去掉本身的话,似乎还是个积性函数,应该可以线性筛筛出来?(这个纯口胡,有错的话还请大佬指正)

第十题:

真的不会一点啊

一排格子1~T,每个格子上最多有一个小球,可以没有,每个小球有一个数值ai,每个时刻,每个小球都有1/2的概率向右走一步,若一个小球走到T处则记录它的数值,并且把它拿走。

当有一个小球追上另一个小球时,两个小球会合并成一个新的小球,新的小球的数值为原来两个小球的乘积。

求在T处所记录的小球数值的和的期望。

T<=100, ai<=100

没时间做,也不会做。(23333

隐隐约约感觉是一个O(n^3)期望DP,不过我是真的不会。

这篇关于2024蓝桥杯国赛C++研究生组游记+个人题解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

深入理解C++ 空类大小

《深入理解C++空类大小》本文主要介绍了C++空类大小,规定空类大小为1字节,主要是为了保证对象的唯一性和可区分性,满足数组元素地址连续的要求,下面就来了解一下... 目录1. 保证对象的唯一性和可区分性2. 满足数组元素地址连续的要求3. 与C++的对象模型和内存管理机制相适配查看类对象内存在C++中,规

Python基于火山引擎豆包大模型搭建QQ机器人详细教程(2024年最新)

《Python基于火山引擎豆包大模型搭建QQ机器人详细教程(2024年最新)》:本文主要介绍Python基于火山引擎豆包大模型搭建QQ机器人详细的相关资料,包括开通模型、配置APIKEY鉴权和SD... 目录豆包大模型概述开通模型付费安装 SDK 环境配置 API KEY 鉴权Ark 模型接口Prompt

在 VSCode 中配置 C++ 开发环境的详细教程

《在VSCode中配置C++开发环境的详细教程》本文详细介绍了如何在VisualStudioCode(VSCode)中配置C++开发环境,包括安装必要的工具、配置编译器、设置调试环境等步骤,通... 目录如何在 VSCode 中配置 C++ 开发环境:详细教程1. 什么是 VSCode?2. 安装 VSCo

C++11的函数包装器std::function使用示例

《C++11的函数包装器std::function使用示例》C++11引入的std::function是最常用的函数包装器,它可以存储任何可调用对象并提供统一的调用接口,以下是关于函数包装器的详细讲解... 目录一、std::function 的基本用法1. 基本语法二、如何使用 std::function

【C++ Primer Plus习题】13.4

大家好,这里是国中之林! ❥前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。有兴趣的可以点点进去看看← 问题: 解答: main.cpp #include <iostream>#include "port.h"int main() {Port p1;Port p2("Abc", "Bcc", 30);std::cout <<

C++包装器

包装器 在 C++ 中,“包装器”通常指的是一种设计模式或编程技巧,用于封装其他代码或对象,使其更易于使用、管理或扩展。包装器的概念在编程中非常普遍,可以用于函数、类、库等多个方面。下面是几个常见的 “包装器” 类型: 1. 函数包装器 函数包装器用于封装一个或多个函数,使其接口更统一或更便于调用。例如,std::function 是一个通用的函数包装器,它可以存储任意可调用对象(函数、函数

2024年流动式起重机司机证模拟考试题库及流动式起重机司机理论考试试题

题库来源:安全生产模拟考试一点通公众号小程序 2024年流动式起重机司机证模拟考试题库及流动式起重机司机理论考试试题是由安全生产模拟考试一点通提供,流动式起重机司机证模拟考试题库是根据流动式起重机司机最新版教材,流动式起重机司机大纲整理而成(含2024年流动式起重机司机证模拟考试题库及流动式起重机司机理论考试试题参考答案和部分工种参考解析),掌握本资料和学校方法,考试容易。流动式起重机司机考试技

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

【专题】2024飞行汽车技术全景报告合集PDF分享(附原数据表)

原文链接: https://tecdat.cn/?p=37628 6月16日,小鹏汇天旅航者X2在北京大兴国际机场临空经济区完成首飞,这也是小鹏汇天的产品在京津冀地区进行的首次飞行。小鹏汇天方面还表示,公司准备量产,并计划今年四季度开启预售小鹏汇天分体式飞行汽车,探索分体式飞行汽车城际通勤。阅读原文,获取专题报告合集全文,解锁文末271份飞行汽车相关行业研究报告。 据悉,业内人士对飞行汽车行业

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象