1380 没有上司的舞会

时间限制: 1 s
空间限制: 128000 KB
题目等级 : 钻石 Diamond

查看运行结果
回到问题
题目描述 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

题意:n个职员 都拥有一个快乐值 但是,没有职员愿和直接上司一起与会(允许同时不出席)  问快乐值的和的最大值

题解:树形dp 从root节点开始向下遍历到叶子节点   dp[i][1] 代表 节点(职员)i参见宴会的快乐值和的最大值

dp[i][0]代表  节点(职员)i不参加宴会的快乐值和的最大值

转移方程如下:x=f[i] x为i的父亲节点

dp[x][1]+=dp[i][0];

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

codevs AC代码

 #include<bits/stdc++.h>
#include<iostream>
#include<cstring>
#include<cstdio>
#include<queue>
#include<algorithm>
#define ll __int64
using namespace std;
int v[];
int dp[][];
int f[];
int n;
int l,k;
void tree(int x)
{
v[x]=;
for(int i=;i<=n;i++)
{
if(v[i]==&&f[i]==x)
{
tree(i);
dp[x][]+=dp[i][];
dp[x][]+=max(dp[i][],dp[i][]);
} }
}
int main()
{
scanf("%d",&n);
int root=;
for(int i=;i<=n;i++)
f[i]=;
for(int i=;i<=n;i++)
scanf("%d",&dp[i][]);
for(int i=;i<=n-;i++)
{
scanf("%d %d",&l,&k);
f[l]=k;
}
scanf("%d %d",&l,&k);
while(f[root]!=)
root=f[root];
tree(root);
printf("%d\n",max(dp[root][],dp[root][]));
return ;
}

hdu AC 代码

 #include<iostream>
#include<cstring>
#include<cstdio>
#include<vector>
using namespace std;
int n;
int dp[][];
int l,k;
int f[];
int v[];
vector<int> ve[];
void dfs(int x)
{
v[x]=;
for(int i=;i<ve[x].size();i++)
{
if(v[ve[x][i]]==)
{
dfs(ve[x][i]);
dp[x][]+=dp[ve[x][i]][];
dp[x][]+=max(dp[ve[x][i]][],dp[ve[x][i]][]);
}
}
}
int main ()
{
while(scanf("%d",&n)!=EOF)
{
int root=;
memset(dp,,sizeof(dp));
for(int i=;i<=n;i++)
f[i]=;
memset(v,,sizeof(v));
for(int i=;i<=n;i++)
{
scanf("%d",&dp[i][]);
ve[i].clear();
}
while(scanf("%d %d",&l,&k))
{
if(l==&&k==)
break;
f[l]=k;
ve[k].push_back(l);
}
while(f[root]!=)
{
root=f[root];
}
dfs(root);
printf("%d\n",max(dp[root][],dp[root][]));
}
return ;
}

codevs 1380/HDU 1520 树形dp的更多相关文章

  1. HDU 1520 树形dp裸题

    1.HDU 1520  Anniversary party 2.总结:第一道树形dp,有点纠结 题意:公司聚会,员工与直接上司不能同时来,求最大权值和 #include<iostream> ...

  2. HDU 1520 树形DP入门

    HDU 1520 [题目链接]HDU 1520 [题目类型]树形DP &题意: 某公司要举办一次晚会,但是为了使得晚会的气氛更加活跃,每个参加晚会的人都不希望在晚会中见到他的直接上司,现在已知 ...

  3. hdu 1520 (树形DP)

    dp[i][0]表示i不参加 dp[i][1]表示i参加 简单的树形dp #include<stdio.h> #include<string.h> #define N 6100 ...

  4. HDU - 1520 树形DP入门题

    写了两种DP,第一种是按照自己习惯来xjb敲的,第二种参考别人 熟悉一下树形DP的套路 dp[i][]是维护i及以下的关系最优值的,所以我觉得两次DP记忆搜索之间不清-1应该是正确的(也就做了一次加法 ...

  5. hdu 1520 树形DP基础

    http://acm.hdu.edu.cn/showproblem.php?pid=1520 父节点和子节点不能同时选. http://blog.csdn.net/woshi250hua/articl ...

  6. poj 2342 && hdu 1520 树形dp

    题意:有n个人,接下来n行是n个人的价值,再接下来n行给出l,k说的是l的上司是k,这里注意l与k是不能同时出现的 链接:点我 dp[i][1] += dp[j][0], dp[i][0] += ma ...

  7. hdu 4123 树形DP+RMQ

    http://acm.hdu.edu.cn/showproblem.php? pid=4123 Problem Description Bob wants to hold a race to enco ...

  8. HDU 1561 树形DP入门

    The more, The Better Time Limit: 6000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Oth ...

  9. HDU 2196树形DP(2个方向)

    HDU 2196 [题目链接]HDU 2196 [题目类型]树形DP(2个方向) &题意: 题意是求树中每个点到所有叶子节点的距离的最大值是多少. &题解: 2次dfs,先把子树的最大 ...

随机推荐

  1. java基础——线程池

    第2章 线程池 2.1 线程池概念 线程池,其实就是一个容纳多个线程的容器,其中的线程可以反复使用,省去了频繁创建线程对象的操作,无需反复创建线程而消耗过多资源. 我们详细的解释一下为什么要使用线程池 ...

  2. head与body(新手向)

    网页文档包含了页头(head)与主体(body) 页头 -是对该网页文档进行描绘的主体信息. -至少含有title与meta. meta描述网页的特征,比如字符编码,平时广泛用的utf-8.且meta ...

  3. js中的||、&&与!用法

    &&和||在JQuery源代码内尤为使用广泛,由网上找了些例子作为参考,对其用法研究了一下: 1. && function a(){ alert("a&quo ...

  4. 关于poi的坑

    背景故事 今天遇上一个坑,关于poi公式计算结果出错的问题,自己打断点debug了半天,虽然没彻底搞清楚为啥不行,但所幸找到了解决办法. 干货 下面不废话,直接贴干货,原先的公式处理代码如下: fin ...

  5. 从Mixin到hooks,谈谈对React16.7.0-alpha中即将引入的hooks的理解

      为了实现分离业务逻辑代码,实现组件内部相关业务逻辑的复用,在React的迭代中针对类组件中的代码复用依次发布了Mixin.HOC.Render props等几个方案.此外,针对函数组件,在Reac ...

  6. TP5数据库操作方法总结

    一.TP5数据库操作方法 1.name()方法        作用 : 指定默认的数据表名(不含前缀)        示例 : Db::name('weiba_post');        返回 : ...

  7. PHP计算两个字符的相似程度similar_text

    在网站开发中,我们会常常要计算两个字符的相似程度,那么PHP为我们提供了一个函数similar_text;  1,similar_text的用法 如果我想计算"ly89cn"和&q ...

  8. JZOJ 4743. 积木

    Description Input Output Sample Input 38 7 63 9 41 10 5 Sample Output 18

  9. 3、python中的字符串

    一.前言 字符串是python中重要的数据类型.字符串就是一段文本,在python中用引号来标示. 二.字符串分类 字符串根据使用场景不同,一共分成3类: (1)单引号.双引号创建的单行字符串: 在单 ...

  10. This application has request the Runtime to terminate it in an unusual way.

    Q: CertsMV.exe  gui popup two dialogs as follow. A: 测试发现是分配内存导致,频繁分配内存(大约6M) 可能是堆管理导致 分配大内存分配失败,程序未对 ...