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,不过我是真的不会。

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

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

相关文章

word里面没有Acrobat选项

加载项被禁止&#xff0c;选择项里面&#xff0c;没有Acrobat选项 文件-》选项 加载项-》com加载项-》转到 添加Acrobat 出现Acrobat选项

[Qt]关于QListWidget、QScrollArea 为什么在QDesigner上设置了之后界面上仍然不生效的问题

前言 最近做了一些有关QListWidget和QScrollArea的控件&#xff0c;我去&#xff0c;这两个控件是真的坑&#xff0c;明明我在QDesigner的操作界面上对这两个控件的界面进行了修改&#xff0c;但是编译出来的软件就是看上去什么都没有&#xff0c;很坑&#xff0c;Gpt也没解决…

【linux】宝塔,首页挂载磁盘,显示使用情况

挂载前&#xff1a; 挂载后&#xff1a; 数据无价&#xff0c;建议&#xff1a;备份需要挂载的磁盘&#xff0c;或者使用新磁盘来进行操作。 1、下载自动挂载磁盘的脚本&#xff1a; wget -O auto_disk.sh http://download.bt.cn/tools/auto_disk.sh 2、给脚本添加执行权限&a…

Re0:从零开始的C++游戏开发 【下】

Re0:从零开始的C游戏开发 &#xff08;下&#xff09; 这是蒟蒻观看B站upVoidmatrix的课程从零开始的提瓦特幸存者的个人笔记【自用】 前言&#xff1a;采用适用于小白的easyx图形库。 第三集 提瓦特の幸存者&#xff08;下&#xff09; 3.1 用户界面实现和设计模式基础 3…

省级交通运输行政执法综合管理平台项目实施方案

背景 党的十八届四中全会提出全面推进依法治国的总目标和重大任务。全会通过的《中共中央关于全面推进依法治国若干重大问题的决定》&#xff0c;开启了中国法治建设的新时代&#xff0c;依法治国已经成为党领导人民治理国家的基本方略。 为了贯彻和落实《交通运输信息化“十三…

资深人士称:AI开发游戏会降低游戏成本和体验,不会降低就业率

易采游戏网6月1日最新消息&#xff1a;本周在TD Cowen会议上&#xff0c;R星的母公司Take-Two的CEO Strauss Zelnick对于人工智能(AI)是否会影响游戏开发行业表达了自己的看法。他坚定地认为&#xff0c;AI绝对会改变游戏的制作方式&#xff0c;但不会降低游戏行业的就业水平。…

Maven打包错误:无效的源发行版:17

1. 报错问题 在用maven进行打包时&#xff08;clean & install&#xff09;&#xff0c;报如下错误&#xff1a; 一开始让我很摸不着头脑&#xff0c;我确定我的pom.xml&#xff0c;还有IDEA中的Project Settings是正确的。 2. 排查 尽管确定&#xff0c;但还是一个个排…

秒杀基本功能开发(显示商品列表和商品详情)

文章目录 1.数据库表设计1.商品表2.秒杀商品表3.修改一下秒杀时间为今天到明天 2.pojo和vo编写1.com/sxs/seckill/pojo/Goods.java2.com/sxs/seckill/pojo/SeckillGoods.java3.com/sxs/seckill/vo/GoodsVo.java 3.Mapper编写1.GoodsMapper.java2.GoodsMapper.xml3.分别编写Seck…

在浏览器里面输入 url,到浏览器显示页面中间发生了什么?

当用户在浏览器中输入URL&#xff08;例如https://www.example.com&#xff09;按下回车键&#xff0c;到浏览器显示页面&#xff0c;这中间浏览器会执行以下步骤&#xff1a; 浏览器解析URL&#xff1a;浏览器解析URL&#xff0c;提取出协议&#xff08;如HTTP或HTTPS&#xf…

每天一个数据分析题(三百四十二)

根据量化对象是业务行为结果还是财务行为结果&#xff0c;可以将指标分为业务指标及财务指标两大类&#xff0c;以下说法正确的是&#xff1f; A. 财务指标是按照财务规则来对财务情况进行量化的指标 B. 业务指标是按照业务规则来对业务情况进行量化的指标 C. 业务指标需要按…

VS(visual studio)搭建QT开发环境插件安装

优先安装QT Qt6 官网QtCreator 下载与安装方法win10_qt6下载-CSDN博客 如果安装vs2019,打开installer,安装c环境 选择c 下载vsix后&#xff0c;双击安装即可。 插件下载&#xff1a; Index of /qtproject/official_releases/vsaddin/ 创建QT项目&#xff1a; 创建完成&…

4K高刷显示器 - 蚂蚁电竞ANT27VU

可以毫不夸张地说&#xff0c;每一局游戏最终能够取得胜利&#xff0c;实际上都与一套极为优秀的电竞 PC 有着紧密的关联&#xff0c;因为其能够提供强大的性能支持与流畅的体验。同样的道理&#xff0c;一套优秀的电竞 PC 若想发挥出最佳的效果&#xff0c;那也都离不开一台能…

leetCode-hot100-数组专题之求和+数学定理+其他

数组专题之求和数学定理其他 求和1.两数之和15.三数之和 数学定理169.多数元素 其他4.寻找两个正序数组的中位数128.最长连续序列 求和 数组求和问题&#xff0c;即计算数组中所有元素的总和&#xff0c;是编程中常见的任务。以下是一些常用的解决方法&#xff1a; 1. 循环遍历…

介绍一下js的节流与防抖

在JavaScript中&#xff0c;节流&#xff08;Throttling&#xff09;和防抖&#xff08;Debouncing&#xff09;是两种常用的优化高频率触发事件的策略。它们主要用于限制函数的执行频率&#xff0c;以避免因频繁触发导致的性能问题。 1. 防抖&#xff08;Debouncing&#xff…

numpy.ndarray是什么类型

numpy.ndarray是什么类型 numpy.ndarray 类型的特点创建 numpy.ndarray示例代码总结 numpy.ndarray是什么类型 numpy.ndarray 是 NumPy 库中的一个核心数据类型&#xff0c;用于表示多维数组。它是 NumPy 中最重要的数据结构之一&#xff0c;提供了高效的数值计算能力。下面是对…

PPP与HDLC的异同

PPP&#xff08;点对点协议&#xff09;与HDLC&#xff08;高级数据链路控制&#xff09;都是数据链路层协议&#xff0c;用于在两点间提供可靠的通信链接&#xff0c;但它们在设计目标、应用场景、功能特性等方面存在一些显著的异同&#xff1a; 相同点&#xff1a; 目的相似…

nn.Embedding使用

nn.Embedding使用 Embedding.weight会从标准正态分布中初始化成大小为&#xff08;num_embeddings, embedding_dim&#xff09;的矩阵 PE矩阵的作用就是替换这个标准正态分布 input中的标号表示从矩阵对应行获取权重来表示单词 # 1.设置embedding结构 max_seq_len 1000 # 句…

配合busco训练Augustus

使用BUSCO的结果来训练Augustus包括以下几个步骤。这些步骤会帮助你利用BUSCO评估的高质量基因来优化Augustus的基因预测模型。 步骤1&#xff1a;运行BUSCO 首先&#xff0c;你需要运行BUSCO来评估你的基因组或转录组。BUSCO会生成一些包含高质量单拷贝直系同源基因的信息文件…

【Java】面向对象的三大特征:封装、继承、多态

封装 什么叫封装&#xff1f; 在我们写代码的时候经常会涉及两种角色&#xff1a; 类的实现者 和 类的调用者。 封装的本质就是让类的调用者不必太多的了解类的实现者是如何实现类的&#xff0c; 只要知道如何使用类就行了&#xff0c;这样就降低了类使用者的学习和使用成本&a…

游戏主播到底是为游戏宣传还是蹭游戏带来的热度

易采游戏网6月1日最新消息&#xff1a;近日知名游戏主播周淑怡在社交平台上发表了自己对《地下城与勇士》手游(简称DNF手游)的点评。作为一款拥有庞大粉丝基础的端游改编作品&#xff0c;DNF手游自发布以来便受到了广泛关注。而周淑怡的点评不仅聚焦于游戏体验本身&#xff0c;…