HNOI2015题解

奇了怪了我上次发的题解怎么不见了?

题意自己戳链接……

Day 1

id=4008">HNOI2015 Arthur

思路:期望DP

直接DP是死也D不出的

转化一下

令f[i][j]——第i张卡在第j回合发动的概率

得到状态转移方程:

f[i][j]——f[i−1][j]∗(1−pi−1)j+f[i−1][j+1]∗(1−(1−pi−1)j+1)

这样下来,答案就为:

∑ni=1∑rj=1f[i][j]∗(1−(1−pi)j)∗di

时间复杂度:O(Tnr)

id=4009">HNOI2015 Fruit

思路:DFS序+总体二分+线段树

设pos[x]——x在DFS序中的位置

我们将水果转化为二维平面上的点(x,y),则有:

每一个盘子能够接到的水果为二维平面上的若干矩形:

对于盘子(x,y),最好还是设deep[x]< deep[y]

若x为y的祖先,则该盘子能够接到的水果满足:一个端点在y的子树内。还有一个端点在x的子树外

否则能够接到的水果满足:一个端点在x的子树内,还有一个端点在y的子树内

假设在这里套上树分治,能够将矩形规模缩小到P*logN

(Orz考场上N*log3N水过的matthew99爷)

只是我们直接使用DFS序(pos[x],pos[y])。能够将矩形规模缩小到2

于是问题变成,二维平面上若干矩形和若干询问点,对于每一个询问点求覆盖它的矩形的第k大。可离线

在线算法挺麻烦的……

总体二分就可以解决这个问题

对于区间[l,r]内的矩形。我们考虑[l,mid]对每一个询问点的覆盖次数

若覆盖次数超过相应的询问k,则说明答案在[mid+1,r]中

否则说明答案在[l,r]中

将询问点分成两份后。递归处理就可以

时间复杂度:O(Nlog2N)

HNOI2015 Dishes

思路:优先队列+字典序

首先排除无解情况

若给定优先顺序出现环状,则说明无解

否则我们考虑整个序列

在1最优先的情况下,使2最优先

将整个序列倒过来,则有:

在1最后的情况下,使2尽量靠后

显然:字典序最大

将整个图倒过来建

每次取可行的最大解增加答案

最后将答案倒序输出就可以

时间复杂度:O(NlogN)

Day 2

HNOI2015 Maple

思路:DAG上DP

设di为i点的入度

对于一个DAG,我们会发现答案为ans=Πni=2di

麻烦的就是多了一条边

这时我们会发现答案增大了

这些增大的方案为那个新边构成的环数

设新边为(x,y),我们能够DP求得增大的方案数

f[i]——y->i对答案的增大的数目

显然:f[i]=∑j−>if[j]∗d−1i

初始状态:f[y]=ans∗d−1y

答案:ans−f[x]

在模质数下可将除法转化为乘法逆元

时间复杂度:O(N+M)

id=4012">HNOI2015 Shop

思路:可持久化树分治结构

事实上没有思路上说的那么复杂……

假设是离线的话,直接一个树分治就搞定

然而题目强制在线。只是每一个点度数不超过3

假设Q=1,我们仅仅需一次树分治

若Q=100。我们能够进行100次树分治

然而Q=200000……

不怂。我们考虑每次树分治

我们会发现,每次分治选出的重心都是一样的

我们将这些重心拎出来,又一次构成一棵树

我们称之为分支结构树

显然,这棵树的深度不超过logN

对于每一个询问,我们发现。仅仅有在分治结构树这个点和它的祖先的答案对这个询问有答案贡献

假设度数>3,我们就须要一个可持久化数据结构来维护每一个重心在分支结构树中的答案

只是这个题度数小,我们能够开3个vector,然后直接合并答案

这样我们仅仅需在分治结构树中计算这个点和它的祖先的答案就可以

时间复杂度:O(QlogN)

id=4013">HNOI2015 Pairwise

思路:树形DP

首先将相等的缩成一个点

然后考虑无解状况,相似Day1 T3

设:一个序列的长度为’<’个数+1

对整个森林进行DP

f[i][j]——以i为根的子树产生的长度为j的序列个数

状态转移方程:f[i][j]=合并f[son[i]][k]

这个合并能够利用背包解决

问题转化为,对于一个长度为x的序列和一个长度为y的序列,将其转化为长度为z的序列共同拥有多少种方案

依据基本组合知识能够知道:(xz)×(x+y−z     x)

时间复杂度:O(N^4)

上一篇:javaScript旋转Base64图片并得到新的base64数据


下一篇:Apache 的 ab 压测工具快速使用