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. DeepLearning tutorial(3)MLP多层感知机原理简介+代码详解

    本文介绍多层感知机算法,特别是详细解读其代码实现,基于python theano,代码来自:Multilayer Perceptron,如果你想详细了解多层感知机算法,可以参考:UFLDL教程,或者参 ...

  2. java基础面试题:写clone()方法时,通常都有一行代码,是什么?

    clone()方法 与new constructor()构造器创建对象不同 是克隆一个新的对象 package com.swift; public class Clone_Test { public ...

  3. vscode wepy 用户自定义代码片段

    VSCode wepy 自定义代码片段 { "wepy-page": { "prefix": "wepy", "body" ...

  4. 济南NOIP冬令营 选拔(select)

    选拔(select) Time Limit:2000ms   Memory Limit:128MB 题目描述 LYK对n个女生有好感.第i个女生的身高为ai. LYK要在这些女生中选拔出一个女生来作为 ...

  5. 用express框架实现反向代理

    目前很多公司开发都是前后台分离开发,于是我用node起了一个服务,用node中的express框架实现了反向代理.(通俗易懂的讲就是我在我的电脑访问不到后台同事的电脑接口,这样做以后就可以在我本地访问 ...

  6. 【jenkins】【java】【tomcat】windows host key verification failed

    适用于windows系统 出现这个问题的原因tomcat启动的用户找不到本地公私钥路径 如果tomcat 启动时候选择 local system account (默认此选项),请把你的公私钥文件(i ...

  7. Java开发学生管理系统

    Java 学生管理系统 使用JDBC了链接本地MySQL 数据库,因此在没有建立好数据库的情况下没法成功运行 (数据库部分, Java界面部分, JDBC部分) 资源下载: http://downlo ...

  8. HDU 3368 Reversi

    http://acm.hdu.edu.cn/showproblem.php?pid=3368 题意:模拟黑白棋,下一步黑手最大可以转化多少个白旗 分析:暴力 原先的思路是找到D然后遍历其八个方向,直到 ...

  9. hdu3374 String Problem 最小最大表示法 最小循环节出现次数

    #include <iostream> #include <cstring> #include <cstdio> using namespace std; int ...

  10. 数据库路由中间件MyCat - 使用篇(1)

    此文已由作者张镐薪授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. 基本概念 直接介绍概念太枯燥了,还是拿个和背景篇相似的例子介绍 业务场景:客户完成下单,快递员接受并更新运单 ...