HNOI2015题解
奇了怪了我上次发的题解怎么不见了?
题意自己戳链接……
Day 1
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)
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)
HNOI2015 Shop
思路:可持久化树分治结构
事实上没有思路上说的那么复杂……
假设是离线的话,直接一个树分治就搞定
然而题目强制在线。只是每一个点度数不超过3
假设Q=1,我们仅仅需一次树分治
若Q=100。我们能够进行100次树分治
然而Q=200000……
不怂。我们考虑每次树分治
我们会发现,每次分治选出的重心都是一样的
我们将这些重心拎出来,又一次构成一棵树
我们称之为分支结构树
显然,这棵树的深度不超过logN
对于每一个询问,我们发现。仅仅有在分治结构树中这个点和它的祖先的答案对这个询问有答案贡献
假设度数>3,我们就须要一个可持久化数据结构来维护每一个重心在分支结构树中的答案
只是这个题度数小,我们能够开3个vector,然后直接合并答案
这样我们仅仅需在分治结构树中计算这个点和它的祖先的答案就可以
时间复杂度:O(QlogN)
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)
转载于:https://www.cnblogs.com/blfbuaa/p/7380795.html
HNOI2015题解相关推荐
- # HNOI2012 ~ HNOI2018 题解
HNOI2012 题解 [HNOI2012]永无乡 Tag:线段树合并.启发式合并 联通块合并问题. 属于\(easy\)题,直接线段树合并 或 启发式合并即可. [HNOI2012]排队 Tag:组 ...
- 洛谷 P3244 / loj 2115 [HNOI2015] 落忆枫音 题解【拓扑排序】【组合】【逆元】
组合计数的一道好题.什么非主流题目 题目背景 (背景冗长请到题目页面查看) 题目描述 不妨假设枫叶上有 \(n\) 个穴位,穴位的编号为 \(1\sim n\).有若干条有向的脉络连接着这些穴位. ...
- 【题解】 [HNOI2015]落忆枫音 (拓扑排序+dp+容斥原理)
原题戳我 Solution: (部分复制Navi_Aswon博客) 解释博客中的两个小地方: \[\sum_{\left(S是G中y→x的一条路径的点集\right))}\prod_{2≤j≤n,(j ...
- 题解-弹飞绵羊 (HNOI2015)
LCT 模板题,分块也很优秀. 分块做法 维护每个点到第一次跳到下一个块时的跳跃次数,并记录其跳到下一个块的第一个点. 注意常见的分块玄学操作 n = min(sqrt(N), 100) 和 n = ...
- BZOJ4012 [HNOI2015]开店
BZOJ4012 [HNOI2015]开店 这道题因为太多人拿这个题卡$BZOJ$,于是成了权限题... 本蒟蒻表示没钱氪金... 无奈,拿出了洛谷:P3241 [HNOI2015]开店 还有$LOJ ...
- [洛谷P3242] [HNOI2015]接水果
洛谷题目链接:[HNOI2015]接水果 题目描述 风见幽香非常喜欢玩一个叫做 osu!的游戏,其中她最喜欢玩的模式就是接水果.由于她已经DT FC 了The big black, 她觉得这个游戏太简 ...
- bzoj 4010: [HNOI2015]菜肴制作 拓扑排序
4010: [HNOI2015]菜肴制作 Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeOnline/ ...
- [JS][dfs]题解 | #迷宫问题#
题解 | #迷宫问题# 题目链接 迷宫问题 题目描述 定义一个二维数组 N*M ,如 5 × 5 数组下所示: int maze[5][5] = { 0, 1, 0, 0, 0, 0, 1, 1, 1 ...
- [JS][dp]题解 | #打家劫舍(一)#
题解 | #打家劫舍(一)# 题目链接 打家劫舍(一) 题目描述 描述 你是一个经验丰富的小偷,准备偷沿街的一排房间,每个房间都存有一定的现金,为了防止被发现,你不能偷相邻的两家,即,如果偷了第一家, ...
最新文章
- SqlServer中循环给多张表建立聚簇索引
- Hibernate中使用未映射为主键的“id”字段进行查询的场景分析
- 高通被欧盟指控垄断 或将面临高达25亿美元罚款
- AnalyticDB for MySQL:PB级云数仓核心技术和场景解析
- java vector_Java Vector sureCapacity()方法与示例
- android xml 画下划线,android – strings.xml:如何从标记前面的空格中删除下划线?...
- java yml value_Spring Boot:从YAML文件加载@Value
- defaultcharacterset mysql_C# .Net+MySQL组合开发Character set ‘gbk’ is not supported的解决方法...
- java jvisualvm linux,从Linux JDK中发出jvisualvm时出现乱码
- select into
- oracle语法_PG数据库sql语法总结,与Oracle有什么不同?
- 5.2 各种类型的Attention: 原理、计算流程
- is not a registered tag library. Must be one of:
- 计算机组成原理硬件设计,计算机组成原理硬件设计报告..doc
- 重新定义高端存储架构,华为Dorado V6树立全闪存新标杆
- html5 live,HTML5 live streaming
- UVALive 5713 Qin Shi Huang's National Road System(次小生成树)
- 浙江大学计算机学院复试拟录取名单,浙江大学计算机学院2015年考研复试拟录名单...
- oracle查询大于某个日期的数据,查看某天(或某个时间区间)的数据,请别用between ... and ......
- 猫和老鼠服务器未响应是怎么回事,猫和老鼠手游怎么玩不了 游戏设置及异常解决方法...
热门文章
- 性别从后台获取得值的那点事儿
- 配置SQL Server 2005 Express的身份验证方式,以及如何启用sa登录名。
- 《LeetCode力扣练习》剑指 Offer 24. 反转链表 Java
- opencv 九点标定_精度与HALCON结果仅差(±0.2mm)
- 二元函数洛必达求极限_由一类特殊的洛必达法则情形展开的讨论 ——小领域的大作用...
- python3 json安装_python3下JSON和JsonPath
- php 表单变量,PHP学习笔记——访问表单变量
- 计算机组成原理考试计算题,计算机组成原理常考计算题.doc
- Php中如何记录本报时间,详细讲解PHP的日期时间函数date()
- python 栈_Python数据结构与算法05:基本结构:栈的应用之括号匹配