codevs 1380/HDU 1520 树形dp
1380 没有上司的舞会
Ural大学有N个职员,编号为1~N。他们有从属关系,也就是说他们的关系就像一棵以校长为根的树,父结点就是子结点的直接上司。每个职员有一个快乐指数。现在有个周年庆宴会,要求与会职员的快乐指数最大。但是,没有职员愿和直接上司一起与会。
第一行一个整数N。(1<=N<=6000)
接下来N行,第i+1行表示i号职员的快乐指数Ri。(-128<=Ri<=127)
接下来N-1行,每行输入一对整数L,K。表示K是L的直接上司。
最后一行输入0,0。
输出最大的快乐指数。
7
1
1
1
1
1
1
1
1 3
2 3
6 4
7 4
4 5
3 5
0 0
5
各个测试点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的更多相关文章
- HDU 1520 树形dp裸题
1.HDU 1520 Anniversary party 2.总结:第一道树形dp,有点纠结 题意:公司聚会,员工与直接上司不能同时来,求最大权值和 #include<iostream> ...
- HDU 1520 树形DP入门
HDU 1520 [题目链接]HDU 1520 [题目类型]树形DP &题意: 某公司要举办一次晚会,但是为了使得晚会的气氛更加活跃,每个参加晚会的人都不希望在晚会中见到他的直接上司,现在已知 ...
- hdu 1520 (树形DP)
dp[i][0]表示i不参加 dp[i][1]表示i参加 简单的树形dp #include<stdio.h> #include<string.h> #define N 6100 ...
- HDU - 1520 树形DP入门题
写了两种DP,第一种是按照自己习惯来xjb敲的,第二种参考别人 熟悉一下树形DP的套路 dp[i][]是维护i及以下的关系最优值的,所以我觉得两次DP记忆搜索之间不清-1应该是正确的(也就做了一次加法 ...
- hdu 1520 树形DP基础
http://acm.hdu.edu.cn/showproblem.php?pid=1520 父节点和子节点不能同时选. http://blog.csdn.net/woshi250hua/articl ...
- 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 ...
- hdu 4123 树形DP+RMQ
http://acm.hdu.edu.cn/showproblem.php? pid=4123 Problem Description Bob wants to hold a race to enco ...
- HDU 1561 树形DP入门
The more, The Better Time Limit: 6000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Oth ...
- HDU 2196树形DP(2个方向)
HDU 2196 [题目链接]HDU 2196 [题目类型]树形DP(2个方向) &题意: 题意是求树中每个点到所有叶子节点的距离的最大值是多少. &题解: 2次dfs,先把子树的最大 ...
随机推荐
- Python中的集合set
>>> help(set) Help on class set in module __builtin__: class set(object) | set(iterable) -- ...
- Bootstrap 历练实例-轮播(carousel)插件方法
方法 下面是一些轮播(Carousel)插件中有用的方法: 方法 描述 实例 .carousel(options) 初始化轮播为可选的 options 对象,并开始循环项目. $('#identifi ...
- 【计数】cf223C. Partial Sums
考试时候遇到这种题只会找规律 You've got an array a, consisting of n integers. The array elements are indexed from ...
- Centos 6版本Device eth0 does not seem to be present,delaying initialization.故障处理
1.1 故障现象 2019年06月14日晚上,公司项目组说有台业务服务器连接不上,比较着急,我通过vpn拨入的方式远程登录到管理控制台查看发现网卡没有获取到IP地址,我尝试重启来重新启动,重启的时候 ...
- JavaScript ES6功能概述(ECMAScript 6和ES2015 +)
JavaScript在过去几年中发生了很大的变化.这些是您今天可以开始使用的12项新功能! 该语言的新增内容称为ECMAScript 6.它也称为ES6或ES2015 +. 自1995年JavaScr ...
- 【linux】CPU,内存对网站的影响
如果读写非常多,建议内存大点 如果涉及到的计算非常多,那就升级CPU
- java的重写(Override) (2013-10-11-163 写的日志迁移
/* *说明方法的重写(又称方法的覆盖)子类并不想原封不动地继承父类的方法,而是想作一定的修改 */ package czbk.jxy.study; /** * @author Archon * @d ...
- [BZOJ1010]玩具装箱toy(斜率优化)
Description P教授要去看奥运,但是他舍不下他的玩具,于是他决定把所有的玩具运到北京.他使用自己的压缩器进行压缩,其可以将任意物品变成一堆,再放到一种特殊的一维容器中.P教授有编号为1... ...
- 子窗体与父窗体调用对方js方法
有时候为了减少一个页面内的代码量,会将部分内容放到子窗体中,如后台管理中用iframe来进行管理 <div> <iframe id="dviframe" src= ...
- js:随记
typeof:没有大写,因为typeof是运算符 *1:是转数字 +string:是转数字,在Date对象上是getTime ""+:是转字符串 "":bool ...