原题地址:http://poj.org/problem?id=2342

题目大意:

  上司和下属不能同时参加派对,求参加派对的最大活跃值。

  关系满足一棵树,每个人都有自己的活跃值(-128~127)

  求最大的活跃度。


树形DP入门题。

首先讲解一下树形DP,顾名思义,树形DP一定是在树上的DP,与普通的DP相似,具有两个方向。

1.根---->叶

2.叶---->根

其中第二种最为常用。实现方法:从根节点开始DFS(深度优先搜索),一直搜索到叶节点,然后根据其特殊性质赋值。通过回溯更新到根节点。得出答案。

回过来说这道题。

首先是状态。

这道题的DP状态共两维,第一维表示自己本身编号,第二维表示去或者不去。

即dp[i][j] j的取值为0或1,1表示去,0表示不去。

最后的答案即为根节点的状态max(dp[root][0],dp[root][1]);

首先常规操作,建边,找根节点。有向图,我们可以通过统计入度和出度来判断根节点和叶节点。

接下来是状态转移方程:

dp[x][1]+=dp[to][0];
dp[x][0]+=max(dp[to][0],dp[to][1]);

很好理解,x是上司,to是下属,通过下属来更新上司。

一个上司可能有多个下属,但是这些下属只能有一个上司,符合树的定义。

如果这个上司去,那么下属只能不去,所以要加上所有的下属不去的状态。即dp[to][0]

如果上司不去,这个时候需要比较下属去或者不去的大小。

有的同学可能会问了,为什么不直接让下属去多好啊,一步贪心,相当于把树进行了黑白染色,要么黑的去,要么白的去,比较一下大小不就好了?

我刚开始纠结了半天,后来发现了题中所给的条件。

关系满足一棵树,每个人都有自己的活跃值(-128~127)。

由于有些员工过于矫情,去派对自己还不活跃,所以之前的贪心是错误的。

之后比较老总(根节点)去或者不去的大小,选择较大值。

上代码:

#include<cstdio>
#include<algorithm>
using namespace std;
int val[];
int indegree[];
int outdegree[];
struct edge
{
int to;
int nxt;
}eg[];
int head[];
int cnt = ;
void add(int x,int y)
{
eg[cnt].to = y;
eg[cnt].nxt = head[x];
head[x] = cnt++;
}
int dp[][];
void dfs(int x)
{
if(outdegree[x]==)
{
dp[x][] = val[x];
return ;
}
for(int i = head[x];i;i=eg[i].nxt)
{
int to = eg[i].to;
dfs(to);
dp[x][]+=dp[to][];
dp[x][]+=max(dp[to][],dp[to][]);
}
}
int main()
{
int n;
scanf("%d",&n);
for(int i = ;i<=n;i++)
{
scanf("%d",&val[i]);
dp[i][] = val[i];
}
for(int i = ;i<=n;i++)
{
int x,y;
scanf("%d%d",&x,&y);
if(x==&&y==)
{
break;
}
indegree[x]++;
outdegree[y]++;
add(y,x);
}
int root;
for(int i = ;i<=n;i++)
{
if(indegree[i]==)
{
root = i;
}
}
dfs(root);
printf("%d",max(dp[root][],dp[root][]));
}
												

Anniversary party(hdu1520)(poj2342)题解的更多相关文章

  1. Anniversary party(hdu1520)

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

  2. [poj2342]Anniversary party_树形dp

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

  3. HDU1520 Anniversary party —— 树形DP

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1520 Anniversary party Time Limit: 2000/1000 MS (Java ...

  4. poj2342 Anniversary party (树形dp)

    poj2342 Anniversary party (树形dp) Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 9128   ...

  5. hdu1520 树形dp Anniversary party

    A - Anniversary party Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I6 ...

  6. 【poj2342】 Anniversary party

    http://poj.org/problem?id=2342 (题目链接) 题意 没有上司的舞会... Solution 树形dp入门题. dp[i][1]表示第i个节点的子树当节点i去时的最大值,d ...

  7. poj2342 Anniversary party

    Anniversary party Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 8028   Accepted: 4594 ...

  8. HDU1520:Anniversary party(树形dp第一发)

    题目:http://acm.hdu.edu.cn/showproblem.php?pid=1520 一个公司去参加宴会,要求去的人不能有直接领导关系,给出每一个人的欢乐值,和L K代表K是L的直接领导 ...

  9. 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. HTTP协议随笔

    代理 代理就是处在客户端和服务端之间的服务器.客户端例如浏览器发送GET请求时,代理服务器接收该请求,并转发该请求至服务所在的服务器.服务器回复的数据和资源在第一时间经过代理服务器,才能回传到浏览器, ...

  2. arguments 使用

    function test(){ var paramsNum = arguments.length; var sum = 0; for(var i = 0;i<paramsNum;i++){ c ...

  3. Smobiler客户端会话

    //客户端会话存值 Client.Session["userid"] = Class1.userid; //客户端会话取值 userid = Client.Session[&quo ...

  4. 2019 边锋游戏java面试笔试题 (含面试题解析)

      本人5年开发经验.18年年底开始跑路找工作,在互联网寒冬下成功拿到阿里巴巴.今日头条.边锋游戏等公司offer,岗位是Java后端开发,因为发展原因最终选择去了边锋游戏,入职一年时间了,也成为了面 ...

  5. 原油PETROLAEUM英语PETROLAEUM石油

    petrolaeum (uncountable) Archaic spelling of petroleum petroleum See also: Petroleum Contents [hide] ...

  6. android.view.ViewRoot$CalledFromWrongThreadException 异常的解决方案

    https://blog.csdn.net/vincent_czz/article/details/7070354 https://stackoverflow.com/questions/210141 ...

  7. React: 有状态组件生成真实DOM结点

    上次我们分析了无状态组件生成 DOM 的过程,无状态组件其实就是纯函数,它不维护内部的状态,只是根据外部输入,输出一份视图数据.而今天我们介绍的有状态组件,它有内部的状态,因此在组件的内部,可以自行对 ...

  8. linux解压缩的常用命令

    1.解包:tar xvf filename.tar, 打包: tar cvf filename DirName 2.解压:gunzip filename.gz, tar zxvf filename.t ...

  9. Android:异步处理之Handler+Thread的应用

    担心原文消失,做此记录,感谢 https://www.cnblogs.com/net168/p/4075126.html 前言 很久很久以前就听说了,每一个android的应用程序都会分别运行在一个独 ...

  10. linux 账户控制

    用户 用户是能够获取系统资源的权限的集合. linux用户组的分类: 管理员 root :具有使用系统所有权限的用户,其UID 为0. 普通用户 : 即一般用户,其使用系统的权限受限,其UID为500 ...