校内OJ上的题,刚开始做的时候以为是道SB题10分钟就能搞完..

然后准备敲了才发现自己是个SB..

刚开始以为是个很裸的TreeDP,然后就只设了两个状态,但是怎么想怎么不对。复杂度好像要爆炸。改成左儿子右兄弟好像根本无法转移..

搜了搜题解,发现不用改成左儿子右兄弟,把两个状态改成三个状态就行了

$f[node][0]$ 在$node$节点的子树被覆盖且$node$被建立

$f[node][1]$ 在$node$节点的子树被覆盖且$node$未被建立

$f[node][2]$ 在$node$节点的子树均被覆盖但是$node$未被覆盖

然后对于$f[node][0]$和$f[node][2]$的状态转移方程可以很好的写出

$f[node][0]=\sum min(f[son][0],f[son][1],f[son][2])+1$

$f[node][2]=\sum f[son][1]$

$f[node][1]$相对来说有些麻烦,状态转移方程没那么好写。简单说一下就是$\sum min(f[son][1],f[son][0])$ 但是限制存在,是必须存在一个$son$的状态为$0$,所以需要在代码上加一些小处理。

需要注意的是,这里的状态必须为$0$的$son$并不是值最小的,而是和状态为$1$的比起来差值最大的。

代码实现上也存在一些细节,不多说。

  1. //OJ 1946
  2. //by Cydiater
  3. //2016.9.18
  4. #include <iostream>
  5. #include <cstdio>
  6. #include <cstring>
  7. #include <string>
  8. #include <algorithm>
  9. #include <queue>
  10. #include <map>
  11. #include <ctime>
  12. #include <cmath>
  13. #include <cstdlib>
  14. #include <iomanip>
  15. using namespace std;
  16. #define ll long long
  17. #define up(i,j,n) for(int i=j;i<=n;i++)
  18. #define down(i,j,n) for(int i=j;i>=n;i--)
  19. ;;
  20. ;
  21. inline ll read(){
  22. ,f=;
  23. ;ch=getchar();}
  24. +ch-';ch=getchar();}
  25. return x*f;
  26. }
  27. ll N,f[MAXN][],LINK[MAXN],len=;
  28. struct edge{
  29. ll y,next;
  30. }e[MAXN];
  31. namespace solution{
  32. inline void insert(int x,int y){e[++len].next=LINK[x];LINK[x]=len;e[len].y=y;}
  33. void init(){
  34. N=read();
  35. up(i,,N){
  36. int x=read(),y=read();
  37. insert(x,y);
  38. insert(y,x);
  39. }
  40. }
  41. void TreeDP(int node,int fa){
  42. f[node][]=;ll sum=;
  43. for(int i=LINK[node];i;i=e[i].next)if(e[i].y!=fa){
  44. TreeDP(e[i].y,node);
  45. f[node][]+=f[e[i].y][];
  46. f[node][]+=min(f[e[i].y][],min(f[e[i].y][],f[e[i].y][]));
  47. sum+=min(f[e[i].y][],f[e[i].y][]);
  48. }
  49. f[node][]=oo;
  50. for(int i=LINK[node];i;i=e[i].next)if(e[i].y!=fa){
  51. f[node][]=min(f[node][],sum-min(f[e[i].y][],f[e[i].y][])+f[e[i].y][]);
  52. }
  53. }
  54. void output(){
  55. cout<<min(f[][],f[][])<<endl;
  56. }
  57. }
  58. int main(){
  59. //freopen("input.in","r",stdin);
  60. using namespace solution;
  61. init();
  62. TreeDP(,);
  63. output();
  64. ;
  65. }

POJ3659 [usaco2008jan_gold]电话网络的更多相关文章

  1. poj2436,poj3659,poj2430

    这两题都体现了dp的核心:状态 dp做多就发现,状态一设计出来,后面的什么都迎刃而解了(当然需要优化的还要动动脑筋): 先说比较简单的: poj2436 由题得知病毒种数<=15很小,于是我们就 ...

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

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

  3. poj3659树状DP

    Cell Phone Network Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 6273   Accepted: 225 ...

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

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

  5. 3336 /P1948电话网络(二分答案)

    3336 电话网络  时间限制: 1 s  空间限制: 32000 KB  题目等级 : 黄金 Gold       题目描述 Description 由于地震使得连接汶川县城电话线全部损坏,假如你是 ...

  6. 10.22~10.28一周经典题目整理(meeting,BZOJ4377,POJ3659)

    meeting:给正n边形每个点染上黑色或者白色,问有多少个同色的等腰三角形. 以正五边形为例这里将最上面的点作为顶点,得到若干对相等的腰 ,注意到以最上面的点作为顶点的等腰三角形的个数,等于颜色相等 ...

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

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

  8. POJ3659 Cell Phone Network(树上最小支配集:树型DP)

    题目求一棵树的最小支配数. 支配集,即把图的点分成两个集合,所有非支配集内的点都和支配集内的某一点相邻. 听说即使是二分图,最小支配集的求解也是还没多项式算法的.而树上求最小支配集树型DP就OK了. ...

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

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

随机推荐

  1. 拦截PHP各种异常和错误,发生致命错误时进行报警,万事防患于未然

    在日常开发中,大多数人的做法是在开发环境时开启调试模式,在产品环境关闭调试模式.在开发的时候可以查看各种错误.异常,但是在线上就把错误显示的关闭. 上面的情形看似很科学,有人解释为这样很安全,别人看不 ...

  2. flash

    1. 1.这种方式已经比较旧了, 2. html.push('<div class="flash-ad" style = "position:relative&qu ...

  3. Java序列化中的SerialVersionUid

    版权声明:本文为博主fbysss原创文章,转载请注明出处 作者:fbysssmsn:jameslastchina@hotmail.com  blog:blog.csdn.NET/fbysss声明:本文 ...

  4. matlab如何建立一个空矩阵,然后往里面赋值

    x=:; y=[]; :length(x) % y=[y;x(i)];%把每一个x都放到Y里,成为一列 y=[y,x(i)];%把每一个x都放到Y里,成为一行 end

  5. Unix 复制文件至指定目录

    cp /gaps/log/20160504/bxdx_20160504.log.Z   /home 将/gaps/log/20160504/bxdx_20160504.log.Z 文件复制到home路 ...

  6. 我的第一个DMZ方案实践

    方案提出的初衷:外网需要定时和不定时推送数据到内网服务器(只要求数据到达内网,没有要求直接连接到内网) 为什么不是直连到内网:每个人第一想到的是不安全,是的,没错不安全.内网的应用和外网的应用最明显的 ...

  7. jqMobile中pageinit,pagecreate,pageshow等函数的执行顺序

    常见的共有5个page函数,刚开始有点迷糊的是到底谁先谁后执行. 实验告诉我们结果: var temp = ''; $('body').live('pagechange', function () { ...

  8. Openstack Basic Networking 翻译

    自己翻译,加强理解.并学习英文和写作. 英文地址:http://docs.openstack.org/networking-guide/intro_basic_networking.html 目录: ...

  9. Qt学习中遇到的问题

    问题: 一个Qt小项目,编译成功并成功运行,但应用程序输出中出现如下异常:FTH: (9892): *** Fault tolerant heap shim applied to current pr ...

  10. [转]JSON 入门指南

    原文地址:http://www.ibm.com/developerworks/cn/web/wa-lo-json/ 尽管有许多宣传关于 XML 如何拥有跨平台,跨语言的优势,然而,除非应用于 Web ...