1380 没有上司的舞会

题目描述 Description

Ural大学有N个职员,编号为1~N。他们有从属关系,也就是说他们的关系就像一棵以校长为根的树,父结点就是子结点的直接上司。每个职员有一个快乐指数。现在有个周年庆宴会,要求与会职员的快乐指数最大。但是,没有职员愿和直接上司一起与会。

输入描述 Input Description

第一行一个整数N。(1<=N<=6000)
接下来N行,第i+1行表示i号职员的快乐指数Ri。(-128<=Ri<=127)
接下来N-1行,每行输入一对整数L,K。表示K是L的直接上司。
最后一行输入0,0。

输出描述 Output Description

输出最大的快乐指数。

样例输入 Sample Input

7
1
1
1
1
1
1
1
1 3
2 3
6 4
7 4
4 5
3 5
0 0

样例输出 Sample Output

5

数据范围及提示 Data Size & Hint

各个测试点1s

树形DP,顾名思义就是在树上分阶段搞状态转移。这道题就是一个既典型又很简单的例子。
首先明确对于每个节点能够决定它对应的最优解的节点就是他的所有儿子节点。
然后,每个节点都有选,不选两种情况,对于这两种情况,需要对它进行分类讨论。
如果这个节点选,那么它的所有儿子节点一定都不选,dp[i][1]=Σ(dp[j][0])+r[i]
如果这个节点不选,他的儿子节点就可选可不选,dp[i][0]=Σmax(dp[j][1],dp[j][0])+r[i]
最终答案为max(dp[root][0],dp[root][1])

/*Cola说必须用邻接链表*/
#include<iostream>
#include<cstdio>
using namespace std;
int n,r[6010],dp[6010][2],head[6010],num,fa[6010];
struct node{int to,pre;
}e[6010];
void Insert(int from,int to){e[++num].to=to;e[num].pre=head[from];head[from]=num;
}
void dfs(int k){for(int i=head[k];i;i=e[i].pre){int v=e[i].to;dfs(v);dp[k][0]+=max(dp[v][0],dp[v][1]);dp[k][1]+=dp[v][0];}dp[k][1]+=r[k];
}
int main(){freopen("manager.txt","r",stdin);scanf("%d",&n);for(int i=1;i<=n;i++)scanf("%d",&r[i]);int x,y;for(int i=1;i<n;i++){scanf("%d%d",&y,&x);Insert(x,y);fa[y]=x;}int root;for(int i=1;i<=n;i++)if(fa[i]==0){root=i;break;}dfs(root);int result=max(dp[root][0],dp[root][1]);printf("%d",result);
}

转载于:https://www.cnblogs.com/thmyl/p/6615955.html

codevs1380 没有上司的舞会相关推荐

  1. 1380 没有上司的舞会

    1380 没有上司的舞会  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 钻石 Diamond 题解 题目描述 Description Ural大学有N个职员,编号为1~N.他 ...

  2. 洛谷 P1352 没有上司的舞会

    洛谷 P1352 没有上司的舞会 Description 某大学有N个职员,编号为1~N.他们之间有从属关系,也就是说他们的关系就像一棵以校长为根的树,父结点就是子结点的直接上司.现在有个周年庆宴会, ...

  3. [LuoguP1352][FJSC]没有上司的舞会

    [LuoguP1352][FJSC]没有上司的舞会(Link) 现在你有一棵树,每一个点有一个点权\(R[i]\),如果选择了\(i\)点,那么\(i\)子树上的所有的点都不能选,现在要求选择若干个点 ...

  4. 树形DP入门(二叉苹果树+没有上司的舞会)

    树形dp学习笔记 - _Lancy - 博客园二叉苹果树 二叉苹果树 没有上司的舞会 二叉苹果树的处理可以说是非常模板了,正常容易联想到倒过来的数字三角形 for(int i=n;i>=1;i- ...

  5. 树形DP——没有上司的舞会

    树形DP--没有上司的舞会 题目 算法分析 Code 总结与反思 题目 Luogu:P1352 https://www.luogu.com.cn/problem/P1352 题目描述 某大学有 nnn ...

  6. 【codevs1380】没有上司的舞会

    problem solution codes /* 用f[x][0],f[x][1] 分别表示x没去和去了的最大价值. f[x][0] = sigmar:max(f[y][0],f[y][1]); f ...

  7. layui树形父子不关联_DP专题7 | 没有上司的舞会 洛谷1352(树形DP)

    高能预警:这是一篇超过5分钟的学习文章,暑假了可以多学会 本篇继续咱们的DP专题,树形DP入门.动态规划每一个类型的DP都是深坑,期望童鞋们自己在这个系列的基础上多花时间进行拓展,学习愉快~ 在讨论树 ...

  8. 洛谷P1352 没有上司的舞会题解

    题目描述 某大学有N个职员,编号为1~N.他们之间有从属关系,也就是说他们的关系就像一棵以校长为根的树,父结点就是子结点的直接上司.现在有个周年庆宴会,宴会每邀请来一个职员都会增加一定的快乐指数Ri, ...

  9. 洛谷P1352 没有上司的舞会(树形DP水题)

    题目描述 某大学有N个职员,编号为1~N.他们之间有从属关系,也就是说他们的关系就像一棵以校长为根的树,父结点就是子结点的直接上司.现在有个周年庆宴会,宴会每邀请来一个职员都会增加一定的快乐指数Ri, ...

最新文章

  1. python零基础怎么学-Python怎么学?零基础如何顺利入门Python?
  2. 区块链BaaS云服务(34)新加坡艾达链ASC
  3. 为什么要用SSM开发框架来架构系统?
  4. 何恺明一作,刷新7项检测分割任务,无监督预训练完胜有监督
  5. 关于StringIndexOutOfBoundsException那些事~
  6. 用户登入身份验证,手机app登入身份验证,TokenAuth身份验证,JSON Web Token(JWT)身份验证
  7. easypoi list中的map导出_EasyPOI简单用例,简单有效
  8. [nowcoder]最长区间
  9. Quartz时间配置(周期任务)
  10. ValidationKey
  11. Vb股票实时交易数据采集源码
  12. 小美赛:模拟机舱病毒传播
  13. Mysql压缩包版的安装教程
  14. Sketch56.1汉化
  15. Python 断言的使用
  16. 5G大规模天线系统架构探讨
  17. 职称计算机为啥要现场拍照,网上确认/现场确认的照片还没拍?你需要这份拍照攻略!...
  18. 电学计算机专业英语,电器电子英语词汇(O)
  19. Python制作动态桌面壁纸程序-摆脱付费-Mili_Wallpaper
  20. Linux下打包压缩war和解压war包 zip和jar

热门文章

  1. redis主从复制_Redis 的主从复制(Master/Slave)
  2. bzoj 3356: [Usaco2004 Jan]禁闭围栏(扫描线+树状数组)
  3. bzoj 3412: [Usaco2009 Dec]Music Notes乐谱
  4. matlab padarray
  5. cube 一站式云原生开源机器学习平台
  6. shell bash常用工具教程(curl,jq)
  7. Echarts数据可视化grid直角坐标系(xAxis、yAxis),开发全解+完美注释
  8. AlignGAN: Learning to Align Cross-Domain Images with Conditional Generative Adversarial Networks
  9. 贺利坚老师汇编课程41笔记:寻址方式的综合应用修改姚明信息的例题
  10. [JZOJ3293] 【SHTSC2013】阶乘字符串