博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
hdu 1520 Anniversary party 树形dp水题
阅读量:5231 次
发布时间:2019-06-14

本文共 2652 字,大约阅读时间需要 8 分钟。

Description

There is going to be a party to celebrate the 80-th Anniversary of the Ural State University. The University has a hierarchical structure of employees. It means that the supervisor relation forms a tree rooted at the rector V. E. Tretyakov. In order to make the party funny for every one, the rector does not want both an employee and his or her immediate supervisor to be present. The personnel office has evaluated conviviality of each employee, so everyone has some number (rating) attached to him or her. Your task is to make a list of guests with the maximal possible sum of guests' conviviality ratings.

Input

Employees are numbered from 1 to N. A first line of input contains a number N. 1 <= N <= 6 000. Each of the subsequent N lines contains the conviviality rating of the corresponding employee. Conviviality rating is an integer number in a range from -128 to 127. After that go T lines that describe a supervisor relation tree. Each line of the tree specification has the form:

L K
It means that the K-th employee is an immediate supervisor of the L-th employee. Input is ended with the line
0 0

Output

Output should contain the maximal sum of guests' ratings.

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

 

公司举行晚会,要求不能有两个是直属上下级的员工同时出现,求最大开心度。

水题,不解释。

#include
#include
#include
#include
#include
using namespace std;const int MAXM = 6005;const int MAXN = 6005;struct Edge{ int to,next;} edge[MAXM];int head[MAXN],tot;void addedge(int u,int v){ edge[tot].to = v; edge[tot].next = head[u]; head[u] = tot++;}void init(){ tot = 0; memset(head,-1,sizeof(head));}int n,m;int dp[MAXN][2];int p[MAXN]={
0};int dfs(int u,int go) { if(dp[u][go]!=-1) return dp[u][go]; if(go) dp[u][go] = p[u]; else dp[u][go] = 0; for(int e=head[u];e!=-1;e=edge[e].next) { int v = edge[e].to; if(go) dp[u][go] += dfs(v,0); else dp[u][go] += max(dfs(v,0),dfs(v,1)); } //printf("%d %d %d\n",u,go,dp[u][go]); return dp[u][go];}int main(){ int u,v; while(scanf("%d",&n)!=EOF) { init(); memset(dp,-1,sizeof(dp)); for(int i=1;i<=n;i++) scanf("%d",&p[i]); bool vis[MAXN]; memset(vis,0,sizeof(vis)); while(1) { scanf("%d%d",&u,&v); if(u==0) break; addedge(v,u); vis[u] = 1; } for(int i=1;i<=n;i++) { if(!vis[i]) addedge(0,i); } printf("%d\n",dfs(0,0)); } return 0;}

转载于:https://www.cnblogs.com/lastone/p/5360774.html

你可能感兴趣的文章
架构图-模型
查看>>
黑马程序员_Java基础枚举类型
查看>>
一位90后程序员的自述:如何从年薪3w到30w!
查看>>
在.net core上使用Entity FramWork(Db first)
查看>>
UIImage 和 iOS 图片压缩UIImage / UIImageVIew
查看>>
MongoDB的数据库、集合的基本操作
查看>>
ajax向后台传递数组
查看>>
疯狂JAVA16课之对象与内存控制
查看>>
[转载]树、森林和二叉树的转换
查看>>
软件测试-----Graph Coverage作业
查看>>
django ORM创建数据库方法
查看>>
创建Oracle synonym 详解
查看>>
php7 新特性整理
查看>>
RabbitMQ、Redis、Memcache、SQLAlchemy
查看>>
linux查看端口占用
查看>>
Sql常见面试题 受用了
查看>>
知识不是来炫耀的,而是来分享的-----现在的人们却…似乎开始变味了…
查看>>
CSS背景颜色、背景图片、平铺、定位、固定
查看>>
口胡:[HNOI2011]数学作业
查看>>
我的第一个python web开发框架(29)——定制ORM(五)
查看>>