转载请注明出处,谢谢:http://www.cnblogs.com/KirisameMarisa/p/4316097.html   ---by 墨染之樱花

【题目链接】http://poj.org/problem?id=2342

【题目描述】一个企业有N个员工,每个人都有一个表示欢乐度的数值。现在要开一场party,不过这些员工里面有上下级关系,每个员工都不希望见到自己的直接上司,即每个员工都不能和直接上司同时出现。求这场party到场的人的总欢乐度的最大值

【思路】最基础的树形dp,现根据上下级关系构成树状图森林,然后在每棵树上进行动态规划,dp[i][0]和dp[i][1]表示以i为根的子树分别在i不来和来的情况下的最大总欢乐度。显然有dp[i][1]=sum(dp[j][0])+a[i],dp[i][0]=sum(max(dp[j][0],dp[j][1])),其中j遍历i的所有儿子节点。最后只需求森林中所有根结点的max(dp[r][0],dp[r][1])的总和

  1. #include <iostream>
  2. #include <ios>
  3. #include <iomanip>
  4. #include <functional>
  5. #include <algorithm>
  6. #include <vector>
  7. #include <sstream>
  8. #include <list>
  9. #include <queue>
  10. #include <deque>
  11. #include <stack>
  12. #include <string>
  13. #include <set>
  14. #include <map>
  15. #include <cstdio>
  16. #include <cstdlib>
  17. #include <cctype>
  18. #include <cmath>
  19. #include <cstring>
  20. #include <climits>
  21. using namespace std;
  22. #define XINF INT_MAX
  23. #define INF 1<<30
  24. #define MAXN 6000+10
  25. #define eps 1e-10
  26. #define zero(a) fabs(a)<eps
  27. #define sqr(a) ((a)*(a))
  28. #define MP(X,Y) make_pair(X,Y)
  29. #define PB(X) push_back(X)
  30. #define PF(X) push_front(X)
  31. #define REP(X,N) for(int X=0;X<N;X++)
  32. #define REP2(X,L,R) for(int X=L;X<=R;X++)
  33. #define DEP(X,R,L) for(int X=R;X>=L;X--)
  34. #define CLR(A,X) memset(A,X,sizeof(A))
  35. #define IT iterator
  36. #define PI acos(-1.0)
  37. #define test puts("OK");
  38. #define _ ios_base::sync_with_stdio(0);cin.tie(0);
  39. typedef long long ll;
  40. typedef pair<int,int> PII;
  41. typedef priority_queue<int,vector<int>,greater<int> > PQI;
  42. typedef vector<PII> VII;
  43. typedef vector<int> VI;
  44. #define X first
  45. #define Y second
  46.  
  47. VI G[MAXN];
  48. int num[MAXN];
  49. int par[MAXN];
  50. int dp[MAXN][];
  51. int N;
  52.  
  53. void dfs(int r)
  54. {
  55. if(G[r].size()==)
  56. {
  57. dp[r][]=;
  58. dp[r][]=num[r];
  59. }
  60. REP(i,G[r].size())
  61. dfs(G[r][i]);
  62. dp[r][]=dp[r][]=;
  63. REP(i,G[r].size())
  64. dp[r][]+=dp[G[r][i]][];
  65. dp[r][]+=num[r];
  66. REP(i,G[r].size())
  67. dp[r][]+=max(dp[G[r][i]][],dp[G[r][i]][]);
  68. }
  69.  
  70. int main()
  71. {_
  72. CLR(par,-);
  73. scanf("%d",&N);
  74. REP(i,N)
  75. scanf("%d",&num[i]);
  76. int x,y;
  77. while(scanf("%d%d",&x,&y))
  78. {
  79. if(x== && y==)
  80. break;
  81. x--;y--;
  82. par[x]=y;
  83. G[y].PB(x);
  84. }
  85. int tot=;
  86. REP(i,N)
  87. if(par[i]==-)
  88. {
  89. dfs(i);
  90. tot+=max(dp[i][],dp[i][]);
  91. }
  92. printf("%d\n",tot);
  93. return ;
  94. }

poj2342 Anniversary party【树形dp】的更多相关文章

  1. [poj2342]Anniversary party_树形dp

    Anniversary party poj-2342 题目大意:没有上司的舞会原题. 注释:n<=6000,-127<=val<=128. 想法:其实就是最大点独立集.我们介绍树形d ...

  2. [poj2342]Anniversary party树形dp入门

    题意:选出不含直接上下司关系的最大价值. 解题关键:树形dp入门题,注意怎么找出根节点,运用了并查集的思想. 转移方程:dp[i][1]+=dp[j][0];/i是j的子树 dp[i][0]+=max ...

  3. poj 2324 Anniversary party(树形DP)

    /*poj 2324 Anniversary party(树形DP) ---用dp[i][1]表示以i为根的子树节点i要去的最大欢乐值,用dp[i][0]表示以i为根节点的子树i不去时的最大欢乐值, ...

  4. POJ 2342 - Anniversary party - [树形DP]

    题目链接:http://poj.org/problem?id=2342 Description There is going to be a party to celebrate the 80-th ...

  5. hdu Anniversary party 树形DP,点带有值。求MAX

    Anniversary party Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others ...

  6. POJ 2342 &&HDU 1520 Anniversary party 树形DP 水题

    一个公司的职员是分级制度的,所有员工刚好是一个树形结构,现在公司要举办一个聚会,邀请部分职员来参加. 要求: 1.为了聚会有趣,若邀请了一个职员,则该职员的直接上级(即父节点)和直接下级(即儿子节点) ...

  7. HDU 1520 Anniversary party [树形DP]

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1520 题目大意:给出n个带权点,他们的关系可以构成一棵树,问从中选出若干个不相邻的点可能得到的最大值为 ...

  8. POJ Anniversary party 树形DP

    /* 树形dp: 给一颗树,要求一组节点,节点之间没有父子关系,并且使得所有的节点的权值和最大 对于每一个节点,我们有两种状态 dp[i][0]表示不选择节点i,以节点i为根的子树所能形成的节点集所能 ...

  9. Anniversary party_树形DP

    Description There is going to be a party to celebrate the 80-th Anniversary of the Ural State Univer ...

  10. HDU1520 Anniversary party 树形DP基础

    There is going to be a party to celebrate the 80-th Anniversary of the Ural State University. The Un ...

随机推荐

  1. poj 1321 棋盘问题 递归运算

    棋盘问题 Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 19935   Accepted: 9933 Description ...

  2. Javascript类型检测

    原地址 http://www.cnblogs.com/fool/archive/2010/10/07/javascrpt.html 开门见山,我们先来看一下代码: var is = function ...

  3. jquery不限图片焦点图

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  4. springmvc定时器

    用到的jar包: aopalliance-1.0.jar commons-logging-1.1.3.jar spring-aop-3.2.4.RELEASE.jar spring-beans-3.2 ...

  5. PCB打样镀层问题

    现在大部分pcb打样所用PCB板一般有锡板和金板之分(一般根据客户要求和产品特 性选择),那么它们有什么区别呢?现在我将他们的区别作比较如下: 1. 从成本方面来说,锡板价格低,金板价格高. 2. 从 ...

  6. Mysql 忘密码 + Phpadmin 修改密码无法登陆

    mysql有时候忘记密码了怎么办?我给出案例和说明!一下就解决了! Windows下的实际操作如下 1.关闭正在运行的MySQL. 2.打开DOS窗口,转到mysql\bin目录. 3.输入mysql ...

  7. android 解决ViewPager双层嵌套的滑动问题

    解决ViewPager双层嵌套的滑动问题 今天我分享一下ViewPager的双层嵌套时影响内部ViewPager的触摸滑动问题 之前在做自己的一个项目的时候,遇到广告栏图片动态切换,我第一时间想到的就 ...

  8. BZOJ 2253: [2010 Beijing wc]纸箱堆叠

    题目 2253: [2010 Beijing wc]纸箱堆叠 Time Limit: 30 Sec  Memory Limit: 256 MBSubmit: 239  Solved: 94 Descr ...

  9. TP的SDK的调用

    1,SDK简介 本SDK是基于ThinkPHP开发类库扩展,因此只能在ThinkPHP平台下使用(ThinkPHP版本要求2.0以上).DEMO中用到了控制器分层,因此运行DEMO需使用ThinkPH ...

  10. 收藏:左路Deep Learning+右路Knowledge Graph,谷歌引爆大数据

    发表于2013-01-18 11:35| 8827次阅读| 来源sina微博 条评论| 作者邓侃 数据分析智能算法机器学习大数据Google 摘要:文章来自邓侃的博客.数据革命迫在眉睫. 各大公司重兵 ...