【贪心】【P5521】[yLOI2019] 梅深不见冬
B [yLOI2019] 梅深不见冬
Background
风,吹起梅岭的深冬;霜,如惊涛一样汹涌;雪,飘落后把所有烧成空,
像这场,捕捉不到的梦。
醒来时已是多年之久,宫门铜环才长了铁锈,
也开始生出离愁。
——银临《梅深不见冬》
Description
给定一棵 \(n\) 个节点的树,在树上行走,每次要么选择一个没有到达过的子节点,要么返回父节点。想要在一个节点 \(u\) 放上梅花当且仅当 \(u\) 的任意子节点 \(v\) 都被放上了 \(w_v\) 朵梅花。在任意时刻可以收回任意节点的梅花。对于每个节点,求如果想在这个节点放梅花,则至少需要准备多少梅花。
Limitations

特殊性质1:每个节点的孩子结点个数不超过 \(2\)
特殊性质2:每个节点的孩子节点个数不超过 \(5\)
特殊性质3:任意一个节点到根的路径上的点数不超过 \(3\),也即树高不超过 \(3\)
对于 \(100\%\) 的数据,保证 \(1 \leq w_i \leq 1000\)
Solution
测试点 \(1\):
只有一个节点,输出 \(w_1\) 即可。期望得分 \(5~pts\)
测试点 \(2~\sim 5\):
爆搜一个行走的顺序,然后可以 \(O(n)\) 判断是否合法。时间复杂度 \(O(n!\times n)\),期望得分 \(20~pts\)
测试点 \(6~\sim~7\):
注意到题目所规定的走法相当于按照树的某个dfs序走,即离开某个节点时必须遍历完它的子树,否则子树中一旦有一个节点没有被遍历到,则永远无法返回这个节点。
如果设在点 \(u\) 上放上 \(w_u\) 朵梅花最少需要 \(ans_u\) 朵梅花的话,考虑对于 \(u\) 的两个孩子 \(x,~y\),如果先走 \(x\),那么首先需要准备 \(ans_x\) 朵梅花,放上了 \(w_x\) 朵梅花,剩余了 \(ans_x - w_x\) 朵花,再走 \(y\),需要准备 \(ans_y\) 朵花,当前有 \(ans_x - w_x\),则需要额外准备 \(\max(ans_y - ans_x + w_x, 0)\) 朵花。先走 \(y\) 的情况类似,比较一下哪种情况更优即可。
时间复杂度 \(O(n)\),期望得分 \(10~pts\)
测试点 \(8~\sim 10\):
孩子节点个数不超过 \(5\),于是爆搜一下走哪个孩子的顺序,用类似子任务 \(3\) 的方法统计,然后取最优的即可。
时间复杂度 \(O(n \times x!)\),其中 \(x\) 为最大的节点孩子个数。期望得分 \(15~pts\)
测试点 \(11~\sim 14\):
树高不超过 \(3\),考虑第 \(3\) 层的节点,答案显然是他们自身的权值,第二层的节点,答案是第三层的权值和。
对于第一层的根节点 \(u\),考虑放满他的孩子的花费和在这个节点上放梅花的花费的关系:
如果放满它的孩子花费为 \(c\),它的孩子的权值和为 \(W\),则会剩余 \(rest = c - W\) 朵梅花,由于 \(W\) 是个常量,\(rest\) 与 \(c\) 正相关。考虑当 \(w_u > rest\) 时,需要额外花费 \(w_u - rest\) 元,花费为 \(w_u - rest + rest = w_u\) 元,当 \(w_u \leq rest\) 时,花费 \(rest\) 元。由此可以发现,当 \(rest\) 减小时,所需要的花费不会增大。又因为 \(rest\) 与 \(c\) 正相关,因此放满它的孩子的花费变地,在这个节点上放梅花的花费不会增加。因此最小化放满它孩子的花费即可得到答案。
对于一个节点 \(x\),设往这个节点上放上梅花至少需要准备 \(ans_x\) 朵梅花,而 \(x\) 的权值为 \(w_x\),我们的问题是选择一个最优的放梅花的序列,使得最终需要准备的梅花最小。这个问题的答案是按照 \(ans_x - w_x\) 的不升序排序即可。
考虑证明这个结论:
设有两个节点 \(i,~j\),设 \(a_i = ans_i - w_i,~a_j = ans_j - w_j\) 且 \(a_i > a_j\)。
考虑先放 \(i\) 再放 \(j\) 需要准备的梅花朵数是 \(\max(ans_i, ans_j + w_i)\)(一式),同理先放 \(j\) 所需要准备的梅花朵数是 \(\max(ans_j, ans_i + w_j)\)(二式)。
由于 \(a_i = ans_i - w_i\),得 \(ans_i = a_i + w_i\)。\(ans_j\) 同理。对一式二式分别提出 \(w\)。
则
\[\text{一式} = \max(ans_i, ans_j + w_i) = \max(a_i + w_i, ans_j + w_i) = w_i + \max(a_i, ans_j)\]
\[\text{二式} = \max(ans_j,ans_i + w_j) = w_j + \max(a_j, ans_i) = w_j + \max(a_j, a_i + w_i) = w_j + a_i + w_i\]
考虑一式的 \(\max\) 如果取 \(a_i\),那么 \(\text{一式} = w_i + a_i < w_i + a_i + w_j = \text{二式}\)
如果取 \(ans_j\),那么 \(\text{一式} = w_i + w_j + a_j < w_i + w_j + w_i = \text{二式}\)
因此,一式恒小于二式,先放 \(i\) 更优。
据此做数学归纳可得,按照 \(ans - w\) 的不升序排序后的序列是最优的。
于是即可排序以后用上面的方式统计答案,时间复杂度 \(O(n \log n)\),期望得分 \(20~pts\)
测试点 \(15~\sim 20\):
发现上面的结论可以应用于这棵树上的任何一个节点,于是每个节点都按照这样的方法排序即可。时间复杂度 \(O(n \log n)\),期望得分 \(30 pts\)。
【贪心】【P5521】[yLOI2019] 梅深不见冬的更多相关文章
- Vijos P1023Victoria的舞会3【贪心+DFS求强联通分量】
链接:Click Me! P1023Victoria的舞会3 Accepted 标签:Victoria的舞会[显示标签] 描写叙述 Victoria是一位颇有成就的艺术家,他因油画作品<我爱北京 ...
- 【POJ - 1862】Stripies (贪心)
Stripies 直接上中文了 Descriptions 我们的化学生物学家发明了一种新的叫stripies非常神奇的生命.该stripies是透明的无定形变形虫似的生物,生活在果冻状的营养培养基平板 ...
- [C++]单源最短路径:迪杰斯特拉(Dijkstra)算法(贪心算法)
1 Dijkstra算法 1.1 算法基本信息 解决问题/提出背景 单源最短路径(在带权有向图中,求从某顶点到其余各顶点的最短路径) 算法思想 贪心算法 按路径长度递增的次序,依次产生最短路径的算法 ...
- [C++]多源最短路径(带权有向图):【Floyd算法(动态规划法)】 VS n*Dijkstra算法(贪心算法)
1 Floyd算法 1.1 解决问题/提出背景 多源最短路径(带权有向图中,求每一对顶点之间的最短路径) 方案一:弗洛伊德(Floyd算法)算法 算法思想:动态规划法 时间复杂度:O(n^3) 形式上 ...
- leetcode刷题-- 4. 贪心
贪心 455分发饼干 假设你是一位很棒的家长,想要给你的孩子们一些小饼干.但是,每个孩子最多只能给一块饼干.对每个孩子 i ,都有一个胃口值 gi ,这是能让孩子们满足胃口的饼干的最小尺寸:并且每块饼 ...
- SharePoint 2013管理中心里【管理服务器上的服务】不见了
打开管理中心,准备配置Managed Metadata Service,发现"管理服务器上的服务"不见了 那我自己拼url直接访问:http://xxxx/_admin/Serve ...
- BZOJ 1692: [Usaco2007 Dec]队列变换 [后缀数组 贪心]
1692: [Usaco2007 Dec]队列变换 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 1383 Solved: 582[Submit][St ...
- Hive安装(二)之表不见了
重启一下电脑,发现表不见了,原来我用的derby存储hive的meta,网上找了一下资料,说是要用mysql, 于是安装mysql sudo apt-get install mysql-serve ...
- HDOJ 1051. Wooden Sticks 贪心 结构体排序
Wooden Sticks Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) To ...
随机推荐
- SpringCloud与Dubbo区别对比
1:SpringCloud与Dubbo区别对比 (1):活跃度 目前SpringCloud的活跃度明显远高于Dubbo(参考github) (2):主要区别 Dubbo Spring Cloud ...
- luogu p2705 小球
题目部分 题目描述 有 R 个红色盒子和 B 个蓝色盒子,还有 R 个红色小球和 B 个蓝色小球.每个盒子只能装一个小球,每个小球都要放在一个盒子里. 如果把一个红色小球放在一个红色盒子里,那么得分是 ...
- Zookeeper到底是什么
1. 什么是Zookeeper 用一句话对其进行定义就是:它是一套高吞吐的分布式协调系统.从中我们可以知道Zookeeper至少具有以下特点: 1.Zookeeper的主要作用是为分布式系统提供协调服 ...
- vue-如何实现带参数跳转页面
[前后端分离项目之vue框架经验总结] 文/朱季谦 在vue框架的前端页面上,若要实现页面之间的带参数跳转,可参考以下实现过程: 例如,点击截图中的“查看试卷”,可实现带参跳转到相应的试卷页面,该功能 ...
- .net core 2.2部署到Windows Server 2012 R2 standard
安装.net core 2.2 下载地址:https://dotnet.microsoft.com/download/dotnet-core/2.2 找到ASP.NET Core Runtime 2. ...
- html 图片滚动代码
我自己也在用的,网页常用!分享出来 最简单易懂源码 <!--下面是向上滚动代码--> <div id=butong_net_top style=overflow:hidden;hei ...
- Django2.0版本以上与pymsql 不匹配问题以及解决方法
Django2.0版本以上与pymsql 不匹配问题以及解决方法 Django 2.0 以上 如果使用pymysql0.93,需要一下两步操作: # 1 第一次报错信息: File "D:\ ...
- leetcode5086:smallest-subsequence-of-distinct-characters
leetcode5086 问题描述 给定一个字符串s,其中只包含小写字母.求s的一个子序列t.要求t包含s中的全部字符.如果答案有多个,输出字典序最小的那个子序列. 解法描述 首先,为s中每个字符打标 ...
- I still have a dream!
当聊起梦想时,哥总会说别跟我谈梦想,我已经戒了!现在的我对梦想并不感冒,总是冷眼旁观很多事情,那些经不起时间检验的事和人,总会消散在历史云烟中,若干年后,又有谁还会记得那些遗弃在历史尘埃中,琐碎的芝麻 ...
- Python Django Vue 项目创建
环境安装忽略,可参考前面个篇幅介绍 1.创建项目 打开pycharm 终端,输入如下,创建项目 # 进入pycharm 项目目录下 cd pyWeb django-admin startproject ...