Time Limit: 10 Sec Memory Limit: 162 MB

Description

Farmer John决定为他的所有奶牛都配备手机,以此鼓励她们互相交流。不过,为此FJ必须在奶牛们居住的\(N(1\leq N\leq10,000)\)块草地中选一些建上无线电通讯塔,来保证任意两块草地间都存在手机信号。所有的\(N\)块草地按\(1..N\) 顺次编号。 所有草地中只有\(N-1\)对是相邻的,不过对任意两块草地\(A\)和\(B\)(\(1 \leq A \leq N; 1 \leq B \leq N; A \neq B\)),都可以找到一个以\(A\)开头以\(B\)结尾的草地序列,并且序列中相邻的编号所代表的草地相邻。无线电通讯塔只能建在草地上,一座塔的服务范围为它所在的那块草地,以及与那块草地相邻的所有草地。 请你帮FJ计算一下,为了建立能覆盖到所有草地的通信系统,他最少要建多少座无线电通讯塔。

Input

第\(1\)行: \(1\)个整数,\(N\)

第\(2..N\)行: 每行为\(2\)个用空格隔开的整数\(A,B\),为两块相邻草地的编号

Output

第\(1\)行: 输出\(1\)个整数,即FJ最少建立无线电通讯塔的数目

Sample Input

5
1 3
5 2
4 3
3 5

输入说明:

Farmer John的农场中有5块草地:草地1和草地3相邻,草地5和草地2、草地4和草地3,草地3和草地5也是如此。更形象一些,草地间的位置关系大体如下:(或是其他类似的形状)

\(4\) \(2\)

\(|\) \(|\)

\(1\)--\(3\)--\(5\)

Sample Output

2

输出说明:

FJ可以选择在草地\(2\)和草地\(3\),或是草地\(3\)和草地\(5\)上建通讯塔。

Source

Gold

Solution

一眼的树形DP。非常像JSOI2018潜入行动对不对,不过那道题是计数题,而且操作方式也有点区别。但是思想还是类似的。

我们仿照那个设一下\(dp[i][2][2]\)分别表示\(i\)这个点,有没有安装,有没有被覆盖。然后我们发现\(dp[i][1][1]\)是个废状态,安装了就一定会被覆盖。

因此我们减少一下:

\(dp[i][0]\):\(i\)这个点没有安装信号塔,也没有其子节点安装的覆盖

\(dp[i][1]\):\(i\)这个点没有安装信号塔,但是被其子节点安装的覆盖

\(dp[i][2]\):\(i\)这个点安装了信号塔

显然\(dp[i][2]\)和\(dp[i][0]\)随便转移:

\[dp[i][2]=\sum \limits_{v\text{是}i\text{的子节点}}^{} \min\{dp[v][0],dp[v][1],dp[v][2]\}
\]

\[dp[i][0]=\sum \limits_{v\text{是}i\text{的子节点}}^{} dp[v][1]
\]

\(dp[i][1]\)就复杂一点了。\(dp[i][1]\)成立的条件是子节点至少要有一个点安装了信号塔。

所以我们统计一个\(是的子节点sum=\sum \limits_{v\text{是}i\text{的子节点}}^{} \min\{dp[v][2],dp[v][1]\}\)。

然后\(是的子节点dp[i][2]=\min \limits_{v\text{是}i\text{的子节点}}^{} sum-\min\{dp[v][2],dp[v][1]\}+dp[v][2]\)

然后就可以愉快地A题了。

#include<cstdio>
#include<algorithm>
#include<cmath>
#include<cstring>
using namespace std;
#define lowbit(x) ((x)&(-(x)))
#define REP(i,a,n) for(register int i=(a);i<=(n);++i)
#define PER(i,a,n) for(register int i=(a);i>=(n);--i)
#define FEC(i,x) for(register int i=head[x];i;i=g[i].ne)
#define dbg(...) fprintf(stderr,__VA_ARGS__)
namespace io{
const int SIZE=(1<<21)+1;char ibuf[SIZE],*iS,*iT,obuf[SIZE],*oS=obuf,*oT=oS+SIZE-1,c,qu[55];int f,qr;
#define gc() (iS==iT?(iT=(iS=ibuf)+fread(ibuf,1,SIZE,stdin),(iS==iT?EOF:*iS++)):*iS++)
inline void flush(){fwrite(obuf,1,oS-obuf,stdout);oS=obuf;}
inline void putc(char x){*oS++=x;if(oS==oT)flush();}
template<class I>inline void read(I &x){for(f=1,c=gc();c<'0'||c>'9';c=gc())if(c=='-')f=-1;for(x=0;c<='9'&&c>='0';c=gc())x=x*10+(c&15);x*=f;}
template<class I>inline void write(I x){if(!x)putc('0');if(x<0)putc('-'),x=-x;while(x)qu[++qr]=x%10+'0',x/=10;while(qr)putc(qu[qr--]);}
struct Flusher_{~Flusher_(){flush();}}io_flusher_;
}//orz laofudasuan
using io::read;using io::putc;using io::write;
typedef long long ll;typedef unsigned long long ull;
template<typename A,typename B>inline bool SMAX(A&x,const B&y){return x<y?x=y,1:0;}
template<typename A,typename B>inline bool SMIN(A&x,const B&y){return y<x?x=y,1:0;} const int N=10000+7,INF=0x3f3f3f3f;
int n,x,y,dp[N][3];
struct Edge{int to,ne;}g[N<<1];int head[N],tot;
inline void Addedge(int x,int y){g[++tot].to=y;g[tot].ne=head[x];head[x]=tot;} inline void DFS(int x,int fa=0){
int sum=0;dp[x][0]=0;dp[x][2]=1;dp[x][1]=INF;
for(register int i=head[x];i;i=g[i].ne){
int y=g[i].to;if(y==fa)continue;DFS(y,x);
dp[x][0]+=dp[y][1];SMIN(dp[x][0],INF);
dp[x][2]+=min(dp[y][0],min(dp[y][1],dp[y][2]));SMIN(dp[x][2],INF);
sum+=min(dp[y][1],dp[y][2]);
}
for(register int i=head[x];i;i=g[i].ne)if(g[i].to!=fa)SMIN(dp[x][1],sum-min(dp[g[i].to][1],dp[g[i].to][2])+dp[g[i].to][2]);
} int main(){
#ifndef ONLINE_JUDGE
freopen("BZOJ1596.in","r",stdin);freopen("BZOJ1596.out","w",stdout);
#endif
read(n);for(register int i=1;i<n;++i)read(x),read(y),Addedge(x,y),Addedge(y,x);
DFS(1,0);write(min(dp[1][1],dp[1][2])),putc('\n');//错误笔记:手残把dp[1][2]打成dp[2][1]
}

USACO2008 Jan 电话网络的更多相关文章

  1. BZOJ1596: [Usaco2008 Jan]电话网络

    1596: [Usaco2008 Jan]电话网络 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 513  Solved: 232[Submit][S ...

  2. 1596: [Usaco2008 Jan]电话网络

    1596: [Usaco2008 Jan]电话网络 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 601  Solved: 265[Submit][S ...

  3. 【bzoj1596】[Usaco2008 Jan]电话网络

    题目描述 Farmer John决定为他的所有奶牛都配备手机,以此鼓励她们互相交流.不过,为此FJ必须在奶牛们居住的N(1 <= N <= 10,000)块草地中选一些建上无线电通讯塔,来 ...

  4. BZOJ 1596: [Usaco2008 Jan]电话网络

    Description Farmer John决定为他的所有奶牛都配备手机,以此鼓励她们互相交流.不过,为此FJ必须在奶牛们居住的N(1 <= N <= 10,000)块草地中选一些建上无 ...

  5. 【bzoj1596】[Usaco2008 Jan]电话网络 树形dp

    题目描述 Farmer John决定为他的所有奶牛都配备手机,以此鼓励她们互相交流.不过,为此FJ必须在奶牛们居住的N(1 <= N <= 10,000)块草地中选一些建上无线电通讯塔,来 ...

  6. BZOJ1596 [Usaco2008 Jan]电话网络 【树形dp】

    题目链接 BZOJ1596 题解 先抽成有根树 设\(f[i][0|1][0|1]\)表示以\(i\)为根,儿子都覆盖了,父亲是否覆盖,父亲是否建塔的最少建塔数 转移一下即可 #include< ...

  7. 【BZOJ】1596: [Usaco2008 Jan]电话网络(树形dp+特殊的技巧)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1596 一开始交了个貌似正确的dp,wa了. 我只考虑了儿子覆盖的情况,没有考虑父亲QAQ 那么我们要 ...

  8. 【BZOJ】1596: [Usaco2008 Jan]电话网络

    [算法]树上贪心 [题解] 因为一个点必须被覆盖,那么它如果没有被子树节点覆盖的话,就覆盖它的父节点. 从叶子开始贪心. 注意,如果它自己已经被选了就不需要选父节点了. #include<cst ...

  9. [BZOJ1596] [Usaco2008 Jan]电话网络(树形DP || 贪心)

    传送门 1.树形DP #include <cstdio> #include <cstring> #include <iostream> #define N 1000 ...

  10. bzoj 1596: [Usaco2008 Jan]电话网络【贪心】

    dfs,如果一个点的儿子.本身.父亲都没有塔,就在父亲上建一个 原理不明-- #include<iostream> #include<cstdio> using namespa ...

随机推荐

  1. Curl命令、Elinks命令、lynx命令、Wget命令、lftp命令

    一.Curl命令 语法 curl(选项)(参数) 选项 -a/--append 上传文件时,附加到目标文件 -A/--user-agent <string> 设置用户代理发送给服务器 -a ...

  2. 20180821-Java封装

    java 封装 在面向对象程式设计方法中,封装(英语:Encapsulation)是指,一种将抽象性函式接口的实作细节部份包装.隐藏起来的方法. 封装可以被认为是一个保护屏障,防止该类的代码和数据被外 ...

  3. drawChild中画阴影,裁剪出圆角

    我们在EasyConstraintLayout中初始化paint,并且关闭硬件加速,然后在drawChild中实现阴影逻辑,最终代码如下. public class EasyConstraintLay ...

  4. selenium来识别数字验证码

    用python写一爬虫,需要模拟登陆,并且有数字验证码.通过selenium+pytesseract+PIL可以实现验证码识别并登陆.三大步: 用selenium截屏,此时截取的是整个页面的 用PIL ...

  5. eureka注册中心wro.css wro.js 404

    注册中心和配置中心放在一个module里面,如果不配置配种中心的访问前缀,会被config拦截.所以改动如下: package com.cloud.stagging.lhcloudeureka; im ...

  6. 测开之路七十一:监控平台之js

    监控平台的js //datetimepicker的初始化函数(主要是对选择时间的下拉框)function init_datetimepicker() { //初始化格式和规则 $('#start'). ...

  7. MySQL 查询性能优化 - EXPLAIN 命令

    查询优化的官方文档在 这里. EXPLAIN 的输出格式 译文 1. MySQL 架构 1.1 MySQL 的简化架构 MySQL 可以简单的分为三层:连接层.服务层.存储引擎层.其中服务层包含了 M ...

  8. Linux 初始化系统(init)- systemd

    wikipedia 浅析 Linux 初始化 init 系统 systemd 中文手册 fedoraproject - systemd 1. Systemd 简介 Systemd 是 Linux 系统 ...

  9. Proxifier全局代理

    0x00前言   成功搭建使用shadowshocks实现代理访问google,然而只能浏览器代理方式使用,不能其他程序使用代理,不利于白帽子匿名安全检测,下面将介绍利用Proxifier实现全局代理 ...

  10. Java IO(3)

    字符流相关 字符流基本上可以类比字节流 只不过是将字节流的byte 换为char. 最根本的两个类是Reader以及Writer Reader的子类有:BufferedReader, CharArra ...