题目描述

  小$w$心里的火焰就要被熄灭了。
  简便起见,假设小$w$的内心是一棵$n-1$条边,$n$个节点的树。
  现在你要在每个节点里放一些个灭火器,每个节点可以放任意多个。
  接下来每个节点都要被分配给一个至多$k$条边远的灭火器,每个灭火器最多能分配给$s$个节点。
  至少要多少个灭火器才能让小$w$彻底死心呢?


输入格式

  第一行三个整数$n,s,k$。
  接下来$n-1$行每行两个整数表示一条边。


输出格式

  一行一个整数表示答案


样例

样例输入:

10 10 3
1 8
2 3
1 5
2 4
1 2
8 9
8 10
5 6
5 7

样例输出:

1


数据范围与提示

  对于$20\%$的数据满足$n\leqslant 100,k\leqslant 2$。
  对于另外$20\%$的数据满足$k=1$。
  对于另外$20\%$的数据满足$s=1$。
  对于$100\%$的数据满足$n\leqslant 10^5,k\leqslant 20,s\leqslant 10^9$。


题解

先来考虑贪心,依次选还没有被覆盖的深度最大的点一定更优,这个用一个堆维护就好啦。

但是可能存在灭火器交集很大的情况。

再来考虑$DP$,设$G[x][k]$表示$x$下面距离为$k$的需要灭火器的房间数,$F[x][k]$表示$x$下面距离为$k$的多余灭火器数。

首先$G[x][k]$要与$F[x][0]$匹配。

还要注意可以跨国$LCA$,所以$G[x][i]$也可以与$F[x][k-i]$匹配,$G[x][i]$与$F[x][k-i-1]$匹配。

那么有转移:

$$F[u][i]=\sum\limits_vF[v][i-1]$$

$$G[u][i]=\sum\limits_vG[v][i+1]$$

初始化$F[x][i]=G[x][i]=1$即可。

匹配的时候用指针维护就好了。

时间复杂度:$\Theta(nk)$。

期望得分:$100$分。

实际得分:$100$分。


代码时刻

#include<bits/stdc++.h>
using namespace std;
struct rec{int nxt,to;}e[200000];
int head[100001],cnt;
int n,s,k;
int f[100001][21],g[100001][21];
bool vis[100001];
int ans,sum;
void add(int x,int y)
{
e[++cnt].nxt=head[x];
e[cnt].to=y;
head[x]=cnt;
}
void dfs(int x)
{
vis[x]=1;
for(int i=head[x];i;i=e[i].nxt)
{
if(vis[e[i].to])continue;
dfs(e[i].to);
for(int j=1;j<=k;j++)
{
f[x][j]+=f[e[i].to][j-1];
g[x][j-1]+=g[e[i].to][j];
g[x][j-1]=min(g[x][j-1],n);
}
}
f[x][0]++;
if(f[x][k])
{
int tmp=(ceil)((double)f[x][k]/s);
ans+=tmp;
g[x][k]+=min(tmp*s,n)-f[x][k];
f[x][k]=0;
}
int fail=k;
for(int i=k;~i;i--)
while(f[x][i]&&fail>=i)
{
int flag=min(f[x][i],g[x][fail]);
f[x][i]-=flag;g[x][fail]-=flag;
if(!g[x][fail])fail--;
}
}
int main()
{
scanf("%d%d%d",&n,&s,&k);
for(int i=1;i<n;i++)
{
int x,y;
scanf("%d%d",&x,&y);
add(x,y);add(y,x);
}
dfs(1);
for(int i=0;i<=k;i++)sum+=f[1][i];
ans+=(ceil)((double)sum/s);
printf("%d",ans);
return 0;
}

rp++

[JZOJ5400]:Repulsed(贪心+树形DP)的更多相关文章

  1. 联赛模拟测试25 C. Repulsed 贪心+树形DP

    题目描述 分析 考虑自底向上贪心 \(f[x][k]\) 表示 \(x\) 下面距离为 \(k\) 的需要灭火器的房间数,\(g[x][k]\) 表示 \(x\) 下面距离为 \(k\) 的多余灭火器 ...

  2. bzoj 1907: 树的路径覆盖【贪心+树形dp】

    我是在在做网络流最小路径覆盖的时候找到这道题的 然后发现是个贪心+树形dp \( f[i] \)表示在\( i \)为根的子树中最少有几条链,\( v[i] \) 表示在\( i \)为根的子树中\( ...

  3. CSP模拟赛 Repulsed(树形DP)

    题面 ⼩ w ⼼⾥的⽕焰就要被熄灭了. 简便起⻅,假设⼩ w 的内⼼是⼀棵 n − 1 条边,n 个节点的树. 现在你要在每个节点⾥放⼀些个灭⽕器,每个节点可以放任意多个. 接下来每个节点都要被分配给 ...

  4. 【模拟8.11】将军令(贪心&&树形DP)

    只看45分的话,是树形DP....(当然也有能拿到70分+的大佬) 40分: 只考虑k==1的情况,树形DP 所以每个节点可能被父亲,自己,儿子控制 设f[MAXN][3],0表示儿子,1表示自己,2 ...

  5. BZOJ 4027:[HEOI2015]兔子与樱花(贪心+树形DP)

    [题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=4027 [题目大意] 樱花树由n个树枝分叉点组成,编号从0到n-1,这n个分叉点由n-1 ...

  6. P2279 [HNOI2003]消防局的设立 贪心or树形dp

    题目描述 2020年,人类在火星上建立了一个庞大的基地群,总共有n个基地.起初为了节约材料,人类只修建了n-1条道路来连接这些基地,并且每两个基地都能够通过道路到达,所以所有的基地形成了一个巨大的树状 ...

  7. CF 463A && 463B 贪心 && 463C 霍夫曼树 && 463D 树形dp && 463E 线段树

    http://codeforces.com/contest/462 A:Appleman and Easy Task 要求是否全部的字符都挨着偶数个'o' #include <cstdio> ...

  8. 【bzoj4027】[HEOI2015]兔子与樱花 树形dp+贪心

    题目描述 很久很久之前,森林里住着一群兔子.有一天,兔子们突然决定要去看樱花.兔子们所在森林里的樱花树很特殊.樱花树由n个树枝分叉点组成,编号从0到n-1,这n个分叉点由n-1个树枝连接,我们可以把它 ...

  9. 51nod 1812 树的双直径 题解【树形DP】【贪心】

    老了-稍微麻烦一点的树形DP都想不到了. 题目描述 给定一棵树,边权是整数 \(c_i\) ,找出两条不相交的链(没有公共点),使得链长的乘积最大(链长定义为这条链上所有边的权值之和,如果这条链只有 ...

随机推荐

  1. 【题解】JSOI2008 最大数

    题目描述 现在请求你维护一个数列,要求提供以下两种操作: 查询操作. 语法:Q L 功能:查询当前数列中末尾L个数中的最大的数,并输出这个数的值. 限制:L不超过当前数列的长度.(L>=0) 插 ...

  2. wpf GeometryDrawing 绘制文字

    <GeometryDrawing x:Key="GeometryDrawingText"> <GeometryDrawing.Geometry> <R ...

  3. 如何判断kbmMWClientQuery当前记录的增改状态?

    有朋友问我,客户端使用了kbmMWClientQuery,对其进行了编辑后,对于指定的记录,如何判断是否是增加的记录,或者是被修改后的记录? 下面这个函数,返回aDataSet当前记录的修改状态: f ...

  4. 2、screen工具

    1.背景 系统管理员经常需要SSH 或者telent 远程登录到Linux 服务器,经常运行一些需要很长时间才能完成的任务,比如系统备份.ftp 传输等等.通常情况下我们都是为每一个这样的任务开一个远 ...

  5. 使用busybox1.21.1制作根文件系统

    1. 下载源码 https://busybox.net/downloads/ 2. 解压 3. 修改Makefile ~/busybox-1.21.1$ vi Makefile 164行: 修改前:C ...

  6. UNetbootin安装linux

    用u盘安装linux系统,最好的方法莫过于用UNetbootin,网址:http://unetbootin.github.io/ UNetbootin allows you to create boo ...

  7. linux工具之iostat

    iostat 是I/O  statistics(输入/输出统计)缩写iostat工具将对系统磁磁盘活动进行监视iostat属于sysstat软件包可以用yum   install   sysstat ...

  8. 异步任务——AsyncTask的初步认识

    ProgressBar_test.class package com.example.administrator.ten_9; import android.app.Activity; import ...

  9. centos nginx https 配置

    1,如果想配置一个域名到指定目录咋弄呢?下面这个 server { listen ; server_name 这里换成你的域名,例如baidu.com; set $root_path '/home/w ...

  10. “美登杯”上海市高校大学生程序设计邀请赛 **D. 小花梨的取石子游戏**

    "美登杯"上海市高校大学生程序设计邀请赛 (华东理工大学) D. 小花梨的取石子游戏 Description 小花梨有