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. ScriptMaker

    0x00 前言 pwn脚本千篇一律,之前也是保存了一份模板,每次都用它,但还是觉得每次都复制一次各种名字还是有的累,于是就写了一份脚本生成器 0x01 ScriptMaker #!/usr/bin/e ...

  2. 拷贝时间测试=cudamelloc+cudahostalloc

    /* * Copyright 1993-2010 NVIDIA Corporation. All rights reserved. * * NVIDIA Corporation and its lic ...

  3. 使用 Repeater方式和完全静态页面使用AJAX读取和提交数据

    1.使用Repeater方式: Comments.aspx <html xmlns="http://www.w3.org/1999/xhtml"> <head r ...

  4. arcgis engine计算点到线的最短距离

    IProximityOperator接口用于获取两个几何图形的距离,以及给定一个Point,求另一个几何图形上离离给定点最近的点.IProximityOperator接口的主要方法有:QueryNea ...

  5. ES6 Reflect使用笔记

    Reflect Reflect 对象和Proxy对象一样, 为操作对象提供了新的API. 为什么使用 Reflect的方式来操作对象? 将 Object 对象上一些明显属于内部的方法放到 Reflec ...

  6. 在React中使用Redux数据流

    问题:数据流是什么呢?为什么要用数据流? 答案:1.数据流是我们的行为与相应的抽象 2.使用数据流帮助我们明确了行为的对应的响应 问题: React与数据流的关系 1.React是纯 V 层的前端框架 ...

  7. 3- vue django restful framework 打造生鲜超市 - model设计和资源导入

    3- vue django restful framework 打造生鲜超市 - model设计和资源导入 使用Python3.6与Django2.0.2(Django-rest-framework) ...

  8. 三十五、MySQL 运算符

    MySQL 运算符 本章节我们主要介绍 MySQL 的运算符及运算符的优先级. MySQL 主要有以下几种运算符: 算术运算符 比较运算符 逻辑运算符 位运算符 算术运算符 MySQL 支持的算术运算 ...

  9. LeetCode954二倍数对数组

    问题:二倍数对数组 给定一个长度为偶数的整数数组 A,只有对 A 进行重组后可以满足 “对于每个 0 <= i < len(A) / 2,都有 A[2 * i + 1] = 2 * A[2 ...

  10. Java课堂作业