传送门

Luogu

解题思路

整体二分。

的确是很难看出来,但是你可以发现输出的答案都是一些可以被看作是关键字处于 \([1, n]\) 的询问,而答案的范围又很显然是 \([0, n]\),这不就刚好满足了整体二分的几个组成部分了吗。  

那么我们要如何求出 \(mid\) 位置的解呢?  

考虑 \(\text{DP}\)

我们很显然可以将子树中的点尽可能合并后再向父亲传递,所以我们对每一次DP的根节点分别记一个子树中的最大值,和一个非严格次大值,然后我们尝试合并这两个值,要是合并不了,就给答案加一,不然就把最大值上传。

正确性和NOIP2018赛道修建有异曲同工之妙

细节注意事项

  • 咕咕咕

参考代码

#include <algorithm>
#include <iostream>
#include <cstring>
#include <cstdlib>
#include <cstdio>
#include <cctype>
#include <cmath>
#include <ctime>
#define rg register
using namespace std;
template < typename T > inline void read(T& s) {
s = 0; int f = 0; char c = getchar();
while (!isdigit(c)) f |= (c == '-'), c = getchar();
while (isdigit(c)) s = s * 10 + (c ^ 48), c = getchar();
s = f ? -s : s;
} const int _ = 100000 + 2; int tot, head[_], nxt[_ << 1], ver[_ << 1];
inline void Add_edge(int u, int v)
{ nxt[++tot] = head[u], head[u] = tot, ver[tot] = v; } int n, ans[_], dp[_]; inline void dfs(int u, int f, int x) {
dp[u] = 0;
int mx = 0, mn = 0;
for (rg int i = head[u]; i; i = nxt[i]) {
int v = ver[i]; if (v == f) continue;
dfs(v, u, x);
if (dp[v] > mx) mn = mx, mx = dp[v];
else mn = max(mn, dp[v]);
}
if (mx + mn + 1 >= x) dp[u] = 0, ++ans[x];
else dp[u] = mx + 1;
} inline void binary(int l, int r, int L, int R) {
if (l > r || L > R) return ;
if (L == R) {
for (rg int i = l; i <= r; ++i) ans[i] = L; return ;
}
int mid = (l + r) >> 1;
ans[mid] = 0, dfs(1, 0, mid);
binary(l, mid - 1, ans[mid], R);
binary(mid + 1, r, L, ans[mid]);
} int main() {
#ifndef ONLINE_JUDGE
freopen("in.in", "r", stdin);
#endif
read(n);
for (rg int u, v, i = 1; i < n; ++i)
read(u), read(v), Add_edge(u, v), Add_edge(v, u);
binary(1, n, 0, n);
for (rg int i = 1; i <= n; ++i) printf("%d\n", ans[i]);
return 0;
}

完结撒花 \(qwq\)

最新文章

  1. Vue2.0组件间数据传递
  2. [Java] Spring MVC 知识点
  3. Winform 生成不需要安装的exe可执行文件 ILMerge使用
  4. 【java IO】使用Java输入输出流 读取txt文件内数据,进行拼接后写入到另一个文件中
  5. spoj 3871. GCD Extreme 欧拉+积性函数
  6. [WF4.0 实战] WPF + WCF + WF 打造Hello World(基础篇)
  7. Oracle自增长序列
  8. java常用字节流
  9. [BZOJ3207] 花神的嘲讽计划Ⅰ (主席树)
  10. Android初级教程短信防火墙
  11. 2010 SD - ICPC D - Emergency
  12. 基于tensorflow的逻辑分类
  13. Zend 缓存
  14. Flume的Source
  15. TimescaleDB比拼InfluxDB:如何选择合适的时序数据库?
  16. #define SIG_DFL ((void(*)(int))0)
  17. 【原创】rabbitmq 学习
  18. 用C++画光(一)&mdash;&mdash;优化
  19. windows下sqli-labs的搭建及学习(POST篇)
  20. ubuntu 18.04 - server版 开机启动脚本

热门文章

  1. 【代码审计】VAuditDemo SQL注入漏洞
  2. L3-023 计算图
  3. Spring Boot 整合MaBatis如何在控制台打印执行的SQL语句
  4. 【原】Mysql最大连接数
  5. [03] Recursive Function递归应用
  6. Numpy中rot90函数实现矩阵旋转
  7. Dire Wolf HDU - 5115
  8. Python3.5学习之旅——day2
  9. 重構電影網源碼 1905.com - 數據庫結構表
  10. error C4430: missing type specifier - int assumed. Note: C++ does not support default-int 解决方法