Description

题目链接

Solution

因为一个节点染黑了子树就都被染黑了,所以最后染黑的点集必然是一棵子树。

可以得出的结论是,如果被染黑的节点在节点 \(a\) 的子树中,而 \(a\) 没有被染黑,那么 \(a\) 的任意次祖先都不会被染黑。

从另一个角度理解就是,染黑的节点在 \(a\) 子树中的大小占比不超过 \(x\) ,那么在 \(a\) 的祖先里占比更小,显然也超不过 \(x\) 。

设 \(f[i]\) 表示节点 \(i\) 不被染黑的最小的 \(x\) ,那么合法情况为:

子节点不染黑(上述结论),或子节点大小在儿子中占比不超过 \(x\)

特殊的,对于叶节点,最差的情况显然是它被染黑,所以 \(f[u]=1\) 。

因此转移方程为

\[f[i]=\max_{v\in son[u]} \bigg\{\min\bigg(f[v], \frac{size[v]}{size[u] - 1}\bigg)\bigg\}
\]

注意到大小不超过 \(k\) 的子树染不染黑没关系,所以

\[ans = \max_{size[u]>k}\{f[u]\}
\]

  1. #include <cmath>
  2. #include <cstdio>
  3. #include <cctype>
  4. #include <cstring>
  5. #include <cstdlib>
  6. #include <iostream>
  7. #include <algorithm>
  8. #define N 500005
  9. using namespace std;
  10. inline int rd() {
  11. int x = 0;
  12. char c = getchar();
  13. while (!isdigit(c)) c = getchar();
  14. while (isdigit(c)) {
  15. x = x * 10 + (c ^ 48); c = getchar();
  16. }
  17. return x;
  18. }
  19. double ans, f[N];
  20. int n, m, tot, hd[N], sz[N];
  21. struct edge{int to, nxt;} e[N << 1];
  22. inline void add(int u, int v) {
  23. e[++tot].to = v; e[tot].nxt = hd[u]; hd[u] = tot;
  24. e[++tot].to = u; e[tot].nxt = hd[v]; hd[v] = tot;
  25. }
  26. void dfs(int u, int fa) {
  27. sz[u] = 1;
  28. for (int i = hd[u], v; i; i = e[i].nxt)
  29. if ((v = e[i].to) != fa) {
  30. dfs(v, u); sz[u] += sz[v];
  31. }
  32. if (sz[u] == 1) {f[u] = 1.0; return;}
  33. for (int i = hd[u], v; i; i = e[i].nxt)
  34. if ((v = e[i].to) != fa)
  35. f[u] = max(f[u], min(f[v], (double)sz[v] / (sz[u] - 1)));
  36. if (sz[u] > m) ans = max(ans, f[u]);
  37. }
  38. int main() {
  39. n = rd(); m = rd();
  40. for (int i = 2; i <= n; ++i) add(i, rd());
  41. dfs(1, 0);
  42. printf("%.10lf\n", ans);
  43. return 0;
  44. }

[ POI 2017 ] Sabota?的更多相关文章

  1. BZOJ 4726 POI 2017 Sabota? 树形DP

    4726: [POI2017]Sabota? Time Limit: 20 Sec  Memory Limit: 128 MBSec  Special JudgeSubmit: 128  Solved ...

  2. yd的拔钉子之路之 POI 2017

    写在前面的一些话 如果我NOIP没退役,这大概会写成一个系列吧,所以这算是系列的开始,要写一些奇怪的东西? 首先解释下什么叫“拔钉子”,其实就是在钉子上做题嘛......至于钉子具体是个什么东西就当面 ...

  3. [ POI 2017 ] Podzielno

    \(\\\) \(Description\) \(B\)进制数,每个数字\(i(i\in [0,B-1])\)有\(A_i\)个.用这些数字组成一个最大的\(B\)进制数\(X\)(不能有前导零,不需 ...

  4. Apache POI解析excel文件

    这里需要用到poi.jar和poi-ooxml.jar  没有的可以去http://mvnrepository.com/下载 import org.apache.poi.POIXMLDocument; ...

  5. 一个基于POI的通用excel导入导出工具类的简单实现及使用方法

    前言: 最近PM来了一个需求,简单来说就是在录入数据时一条一条插入到系统显得非常麻烦,让我实现一个直接通过excel导入的方法一次性录入所有数据.网上关于excel导入导出的例子很多,但大多相互借鉴. ...

  6. Java使用POI为Excel打水印,调整列宽并设置Excel只读(用户不可编辑)

    本文介绍在Java语言环境下,使用POI为Excel打水印的解决方案,具体的代码编写以及相关的注意事项. 需求描述: 要求通过系统下载的Excel都带上公司的水印,列宽调整为合适的宽度,并且设置为不可 ...

  7. poi入门之读写excel

    Apache POI 是用Java编写的免费开源的跨平台的 Java API,Apache POI提供API给Java程式对Microsoft Office格式档案读和写的功能.该篇是介绍poi基本的 ...

  8. 位置信息类API调用的代码示例合集:中国省市区查询、经纬度地址转换、POI检索等

    以下示例代码适用于 www.apishop.net 网站下的API,使用本文提及的接口调用代码示例前,您需要先申请相应的API服务. 中国省市区查询:2017最新中国省市区地址 经纬度地址转换:经纬度 ...

  9. EXCEL上传POI

    Java SpringMVC POI上传excel并读取文件内容 2017年11月27日 15:26:56 强人锁男. 阅读数:15329   用的SSM框架,所需要的jar包如图所示:,链接地址:j ...

随机推荐

  1. mysql---列的选取原则

    列选择原则: :字段类型优先级 整型 > date,整型>浮点型,time > enum,char>varchar > blob 列的特点分析: 整型: 定长,没有国家/ ...

  2. boogo08---中间件

    package main //中间件1:只允许特定host请求过来 import ( "fmt" "net/http" ) //SingleHost是一个中间件 ...

  3. java 获取路径

    1.利用System.getProperty()函数获取当前路径:System.out.println(System.getProperty("user.dir"));//user ...

  4. confluence的使用

    搜索文档的技巧 在confluence中进行搜索的时候,也需要使用通配符.比如搜索cmscontext,需要这么搜索cmscontex*,如果搜索的话,cmscontext.geturl是会被过滤掉的 ...

  5. hiho Mission Impossible 6(模拟 未提交验证。。)

    题意:模拟文本操作 思路:模拟 #include<iostream> #include<stdio.h> #include<string.h> using name ...

  6. EOJ Monthly 2018.4 (E.小迷妹在哪儿(贪心&排序&背包)

    ultmaster 男神和小迷妹们玩起了捉迷藏的游戏. 小迷妹们都希望自己被 ultmaster 男神发现,因此她们都把自己位置告诉了 ultmaster 男神,因此 ultmaster 男神知道了自 ...

  7. JAVA interrupte中断线程的真正用途

    Java线程之中,一个线程的生命周期分为:初始.就绪.运行.阻塞以及结束.当然,其中也可以有四种状态,初始.就绪.运行以及结束. 一般而言,可能有三种原因引起阻塞:等待阻塞.同步阻塞以及其他阻塞(睡眠 ...

  8. HBase之四--(2):spring hadoop 访问hbase

    1.  环境准备: Maven Eclipse Java Spring 2. Maven  pom.xml配置 <dependency> <groupId>org.apache ...

  9. jqGrid Bootstrap

    <!DOCTYPE html> <html lang="en"> <head> <!-- The jQuery library is a ...

  10. pythonchallenge 2

     pythonchallenge是一个很有意思的学习python的网站,通过用程序解开一个谜,可以进入到下一个level,总共有几十个level,网址是http://www.pythonchallen ...