[关闭]
@yang12138 2019-04-28T11:31:18.000000Z 字数 3491 阅读 3746

华南理工大学软件文化节“三七互娱杯”程序设计竞赛题解

未分类


A: HRY and signin problem

签到题,直接输出就好了。时间复杂度

B: HRY and codefire
表示当前两个账号分别是级,并且下一场比赛使用级的账户参赛,达到级仍需要的参赛次数的期望。那么初始化,然后转移是:

.
这里的转移涉及到了环,可以联立下面的方程组:

消元之后得到:

可以通过先计算大的来计算整个数组.
时间复杂度

C: HRY and fibonacci
先计算的前项和:


可以通过类似的方法求出
线性递推,考虑矩阵快速幂优化。此题是区间操作,考虑线段树。
线段树每个节点维护,然后区间加的时候,相当于做矩阵乘法:


如果是加正整数的话同理,先用矩阵快速幂求出转移矩阵的次方,再进行线段树节点值的更新。
时间复杂度

D: HRY and Abbas

枚举每个位置,计算从它开始下一颗子弹在的位置。
有一个简单的写法,考虑每两个相邻子弹之间的长度(不含有子弹的位置),那么都加上
时间复杂度

E: HRY and array
考虑对答案的贡献为,所以的期望是


要求输出位小数,模拟除法即可。
时间复杂度

F: HRY and balls
盒子数很少,而且可以知道每个盒子最多被操作一次,考虑状态压缩
首先去掉不需要操作的盒子,即那些一开始的时候,盒子里面的球所在的位置均已经是正确的盒子,显然这些盒子不需要进行操作。
表示已经操作了集合的盒子,盒子当前的球数。
表示操作完集合的盒子需要最少的时间。
转移式子是
可以预处理出来。
总时间复杂度为

G: HRY and ec-final
首先意识到内最大的素数间隔不会很大,打表暴力计算一下可以知道最大素数间隔不到,也就是说,如果给定的序列是从的欧拉函数截取下来的,那么肯定有一个位置是素数,素数的欧拉函数是,枚举每个位置,假设这个位置是素数,然后暴力计算相应位置的欧拉函数,看是否能对应上。理论时间复杂度是,但是远远达不到这个数值,加上剪枝(每当有一个位置对应不上的时候就退出这个位置的计算)之后非常快。

H: HRY and tree
考虑计算每个边的贡献,按边从小到大排序,每次取出最小的边插入,并计算边连接的两个联通块的大小,这条边的贡献是。正确性显然。
维护联通块大小可以用并查集。
时间复杂度,此处指反阿克曼函数,在这里可以看作一个非常小的常数。
可能也能用点分治卡过去,这是点分治裸题,为了让套点分治板子的选手难受一点,特意把数据开到百万级,要是还能用点分治过这题,说明常数十分的优秀。。。

I: HRY and mobius
显然只需要考虑的情况。

,用杜教筛计算。

时间复杂度

J: HRY and Fight the landlord
没啥好说的,照着题意模拟就行了,祝大家打牌开心。。。
给几个特殊数据好了:
A A A A 2 2 2 2是N0; 3 3 3 3 4 4 4 4是Ye5

K: HRY and Repeaters
先把个母串用不同的特殊符号串起来,求出后缀数组和高度数组来。对每个后缀,记录它是原先的个母串中的第几个的后缀。对每个查询,二分出它在后缀数组中的位置,最后需要算的是在后缀数组的个后缀中,有多少个后缀所在母串是在范围内。这个可以建立一个可持久化线段树来计算。
时间复杂度

L: HRY and cats

首先枚举有向线段(表示第个树桩到第个树桩的向量),判断是否所有猫都在这个向量的左边(用叉乘算),只留下判断结果为“是”的有向线段,然后满足条件的多边形肯定是由这些有向线段组成的。那么可以枚举起点,求起点到其他点最少使用的线段数,也就是求最短路。如果能到这个有向线段是合法的,那么是一个可行解。对所有可行解求最小值即可。无解输出

M: HRY and ball 2
这题是最后加进来的防AK题,题目本身不难,但是因为上面的题都相对简单而且码量不大所以。。
这题是我2017年在去西安参加区域赛的路上想到的问题,当时很久才想出解法来,也写了很久,时隔一年多终于把它拿出来祸害人了。。

,也就是表示把个球分成若干组的方案数。这里盒子是一样的,球是不一样的。那么我们可以枚举前个球有哪些和在同一个盒子里,那么就有:


转换一下就成了:

,那么就是:


和式内是卷积形式,考虑,不过是自身卷上另一个序列的卷积。。
考虑分治,计算时,先计算的,然后把的答案贡献到中(用),然后再计算。由于给定的模数本身就是可以用的费马素数,所以直接就行了。时间复杂度

添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注