给千图网等网站做设计赚钱吗,河南注册公司代理,企业网站建设目的意义,做摄影网站的目的是什么意思Day0
开始复习#xff0c;过了一遍大部分板子
本来打算再学一遍SAM#xff0c;但是想到去年考了字符串大题今年应该不会再考了吧。。
过了一遍数据结构和图论#xff0c;就1点了
两点的时候还没睡着#xff0c;舍友打游戏好像打到2点过。。
Day1
相当困
第一题…Day0
开始复习过了一遍大部分板子
本来打算再学一遍SAM但是想到去年考了字符串大题今年应该不会再考了吧。。
过了一遍数据结构和图论就1点了
两点的时候还没睡着舍友打游戏好像打到2点过。。
Day1
相当困
第一题
数田字有多少条直线可以只经过两个点12条
第二题
求长度42的置换中周期恰好为2024的置换个数
首先20248*11*23然后8112342然后就是组合数C(42,8)*C(34,11)
结果赛后复盘的时候发现不对劲想简单了还有环内部的顺序需要计算应该还要乘上每个环长度的欧拉函数值
第三题
限流器T条访问记录每条访问记录有一个时间戳每n个时间单位作为一个限流区间每个区间最多能提供m次访问机会。求成功访问的次数。
由于时间给的很小1000直接除一下n放桶里最后和m取min再求和。
第四题
给一个数组a[i]求把所有数加上x再mod k之后小于等于t的数最多能有多少个
先对所有a[i] mod一下k变成求一段长度为t1的区间最多能够覆盖多少值由于这个问题是环形的我们套路地把数组a[i]的每个值加上k的复制一段在后面转化为区间问题。
贪心一下我们选取的区间左端点一定是某个a[i]值否则就可以让区间更靠后以此获取更多覆盖的区域。
two-pointers扫一遍就可以知道结果了。注意边界条件判断。
当然数据范围比较温和二分查找logn也可以过。
此时934。
第五题
小模拟模拟vim指令编辑字符串n^3
发现insert是中文引号很诡异但是不影响结果
这题写了我一个小时厉害吧我是真的唐啊
写完1024了
第六题
一个字符串定义一个合法划分划分中任意两个相邻的子串不能有公共字符。求该字符串中所有长度为1~5的本质不同的子串这些子串在任意一个合法划分中都没有出现请将他们按字典序输出。
首先合法划分必然存在怎么有点像绕口令ababaabb可分为a|b|a|b|aa|bb
考虑一个串能在合法划分中出现例如abcde那么他的两端必然没有与a、b、c、d、e这五个字符相同的字符否则这个子串就不能被划分出来。
于是我们枚举所有长度1~5的串判断他是否能在合法划分中出现能的话就给他的哈希值打上一个标记因为字符串长度只有5maplong long就可以过。
然后我们第二次扫描所有长度为1~5的子串看哈希值是否被标记过如果没有就加入答案的集合。
最后对答案集合进行排序、去重就结束了。
ps为什么不直接求不合法的子串因为一段字符串中aabaccaba例如aba实际上是可以在合法划分中出现的划分为aa|b|a|cc|aba但是如果直接求的话a|aba|cc|a|b|a就发现前面这里的aba实际上不合法。
写完调完直接1100
第七题
一个带权有向图n个点n50给出邻接矩阵m次查询m1000查询u点到v点恰好经过c条边的最短路径并且可以将路径上的一条边边权减半但是多次经过的话只能减半一次。
一眼就是倍增floyd再加上一个求路径max同样可以倍增做。
不过时间复杂度非常逆天O(m*n^3*logc)考虑怎么优化
发现我不会70分遗憾离场。
此时1132很急后面还有三道大题没看。
第八题
给一段序列它来源于对一棵树的先序遍历的节点深度已知该序列的一部分未知的部分用-1
代替求这个序列一共有多少种可能。
首先发现先序遍历的深度序列任意一个值都满足a[i]a[i-1]1i1
然后对于每一段-1我们都可以对其进行计数。
设f[i][j]为第i位的值为j时序列1~i构成的方案数
f[i][j]f[i-1][j-1]f[i-1][j]f[i-1][j1]……f[i-1][i-1]即对前一个f[i-1]的一个后缀和再向后平移一位
假设这一段-1区间为[l,r]的前一个数为x后一个数为y那么设f[l-1][x]1
最终答案为f[r1][y]
最后把每段的答案乘起来就是最终答案。
考虑如何优化这个后缀和
发现我不会30分遗憾离场。
做完之后1215顿时觉得可以开摆了。
赛后复盘其实觉得不应该放弃这一点的毕竟初值只有一个1后面也只查询一个点应该是可以用数学公式推出来的。
第九题
n个点每两个点i,j之间有一条边若i*j为完全平方数则边权为1否则为0。
特殊生成树定义为任意一个点都必定有一条边连接一个比自己权值小的点。
对每个k求边权为kk0~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-cnticnti*x)的多项式系数。
最后的100分应该是NTT过程中其实可以优化因为cnti可能为0这样可以在常数上小一点然后n(logn)^2过掉。
只可惜时间不够但即便是时间够我也不会写NTT了。。。。
真的很菜欸。。60分遗憾离场了。
至于cnt的求法先把n分解质因数对每个质因子次数ai如果是偶数就凑(0、2、4、……、ai)
如果是奇数就凑1、3、5、……、ai也就是(ai1)/2种凑法。然后把每个质因子凑法乘起来再-1减掉本身就是cnt了。复杂度O(n*sqrt(n))
如果不去掉本身的话似乎还是个积性函数应该可以线性筛筛出来这个纯口胡有错的话还请大佬指正
第十题
真的不会一点啊
一排格子1~T每个格子上最多有一个小球可以没有每个小球有一个数值ai每个时刻每个小球都有1/2的概率向右走一步若一个小球走到T处则记录它的数值并且把它拿走。
当有一个小球追上另一个小球时两个小球会合并成一个新的小球新的小球的数值为原来两个小球的乘积。
求在T处所记录的小球数值的和的期望。
T100, ai100
没时间做也不会做。23333
隐隐约约感觉是一个O(n^3)期望DP不过我是真的不会。