华山论剑(没有上司的舞会)

题目描述

一日,小策如往常一般打开了自己的传奇,刚上线不久,就收到了帮主的私信。原来帮派里要召开一次武功比拼,让他来邀请各帮派人员,因为有些侠客还是萌新,所以需要小策挨个选取战力高的侠客。

本帮派——华山,实行了师徒制,每位侠客都有自己的师傅,师傅也有自己的师傅,一直到本帮派帮主。

每位侠客都有自己的战力,因为本次比拼会在全区直播,大家肯定愿意看更加激烈的战斗,所以肯定是战力越高越好。

但是还有一个要求,当邀请了一位侠客的师傅的时候,便不能再邀请那位侠客了。

请你帮助小策来计算,邀请哪些侠客可以使武会的战力总和最大,求最大的战力总和。

注:并不是师傅的战力一定比徒弟高,也有“青出于蓝而胜于蓝”的情况,但是师徒关系是不变的。

为了便于计算,我们将每位侠客表上编号 \((1...n)\) 。

输入格式

第 \(1\) 行是一个整数 \(n\) ,表示有 \(n\) 个侠客;\((1\leq n\leq 6000)\)

第 \(2\) 行到第 \((n+1)\) 行,每行一个整数,第 \((i+1)\) 行的整数表示第 \(i\) 号侠客的战力值 \(r (-128\leq r\leq 127)\) (这里你们可能会疑惑了,但是玩游戏怎么不会有个坑逼呢,拉低全员战力)

第 \((n+2)\) 行到第 \((2n+1)\) 行,每行输入一堆整数 \(x\),\(y\),表示 \(y\) 是 \(x\) 的师傅

最后一行输入 \(0,0\)

输出格式

输出一行一个整数代表最大的战力总和

样例

样例输入

3
52
42
36
1 3
3 2
0 0

样例输出

94

基本思路

根据题目判断,由于有徒弟师傅这种关系,可以讲整个帮派看成一整颗树,帮主便是树根,每位侠客的战力值便是每个树节点的权值,现在就可以判断整个题就是对树形 \(dp\) 的考察。

但是与常规树形 \(dp\) 不同的是,这个题有个限制条件,便是:父节点被选中时,他的子节点便不能被选中了。

如果说仅仅定义一个一维的 \(dp[i]\) ,无法进行限制条件的判断。

所以,需要定义一个二维的 \(dp[i][j]\) ,表示的是以 \(i\) 为根节点的子树,\(i\) 去不去时的最大战力值,\(j\) 表示 \(i\) 去不去的状态,\(j=1\) 便是 \(i\) 去,\(j=0\) 便是 \(i\) 不去。

那么状态转移方程便可以得出:

师傅来,徒弟不能来。师傅不来,徒弟就能来。所以,决策便是师傅到底来不来,即对 \(dp[i][j]\) 中的 \(j\) 讨论取 \(1\) 还是取 \(0\) 了。

for(int i=head[now];i;i=e[i].next){
dp[now][flag]+=dfs(e[i].to,!flag);
}

剩下的就注意有负的战力值,初始化的时候就需要注意一下。

代码

#include<bits/stdc++.h>
using namespace std;
const int maxn=10000+50;
struct Edge{
int next;
int to;
}e[maxn];
int dp[maxn][2];
int a[maxn];
int in[maxn];
int head[maxn];
int cnt=0;
int n,x,y,root;
void insert(int u,int v){
e[++cnt].next=head[u];
head[u]=cnt;
e[cnt].to=v;
in[v]++;
}
int dfs(int now,bool flag){
if(!head[now]){
if(flag){
return a[now];
}else{
return 0;
}
}
for(int i=head[now];i;i=e[i].next){
dp[now][flag]+=dfs(e[i].to,!flag);
}
return dp[now][flag];
}
int main(){
scanf("%d",&n);
for(int i=1;i<=n;i++){
scanf("%d",&a[i]);
}
for(int i=1;i<=n;i++){
dp[i][1]=max(a[i],0);
}
for(int i=1;i<n;i++){
scanf("%d%d",&x,&y);
insert(y,x);
}
scanf("%d%d",&x,&y);
for(int i=1;i<=n;i++){
if(!in[i]){
root=i;
break;
}
}
dfs(root,0);
dfs(root,1);
cout<<max(dp[root][0],dp[root][1])<<endl;
return 0;
}

华山论剑(没有上司的舞会)——树形dp的更多相关文章

  1. [luogu]P1352 没有上司的舞会[树形DP]

    本Lowbee第一次写树形DP啊,弱...一个变量写错半天没看出来...... 题目描述 某大学有N个职员,编号为1~N.他们之间有从属关系,也就是说他们的关系就像一棵以校长为根的树,父结点就是子结点 ...

  2. 『没有上司的舞会 树形DP』

    树形DP入门 有些时候,我们需要在树形结构上进行动态规划来求解最优解. 例如,给定一颗\(N\)个节点的树(通常是无根树,即有\(N-1\)条无向边),我们可以选择任意节点作为根节点从而定义出每一颗子 ...

  3. 洛谷P1352 没有上司的舞会——树形DP

    第一次自己写树形DP的题,发个博客纪念`- 题目来源:P1352 没有上司的舞会 题目描述 某大学有N个职员,编号为1~N.他们之间有从属关系,也就是说他们的关系就像一棵以校长为根的树,父结点就是子结 ...

  4. CodeVS1380 没有上司的舞会 [树形DP]

    题目传送门 没有上司的舞会 题目描述 Description Ural大学有N个职员,编号为1~N.他们有从属关系,也就是说他们的关系就像一棵以校长为根的树,父结点就是子结点的直接上司.每个职员有一个 ...

  5. 没有上司的舞会 树形dp

    题目描述 某大学有N个职员,编号为1~N.他们之间有从属关系,也就是说他们的关系就像一棵以校长为根的树,父结点就是子结点的直接上司.现在有个周年庆宴会,宴会每邀请来一个职员都会增加一定的快乐指数Ri, ...

  6. P1352 没有上司的舞会——树形DP入门

    P1352 没有上司的舞会 题目描述 某大学有N个职员,编号为1~N.他们之间有从属关系,也就是说他们的关系就像一棵以校长为根的树,父结点就是子结点的直接上司.现在有个周年庆宴会,宴会每邀请来一个职员 ...

  7. P1352 没有上司的舞会[树形dp]

    题目描述 某大学有N个职员,编号为1~N.他们之间有从属关系,也就是说他们的关系就像一棵以校长为根的树,父结点就是子结点的直接上司.现在有个周年庆宴会,宴会每邀请来一个职员都会增加一定的快乐指数Ri, ...

  8. P1352 没有上司的舞会&&树形DP入门

    https://www.luogu.com.cn/problem/P1352 题目描述 某大学有N个职员,编号为1~N.他们之间有从属关系,也就是说他们的关系就像一棵以校长为根的树,父结点就是子结点的 ...

  9. 洛谷 P1352 没有上司的舞会 树形DP板子

    luogu传送门 题目描述: 某大学有n个职员,编号为1~n. 他们之间有从属关系,也就是说他们的关系就像一棵以校长为根的树,父结点就是子结点的直接上司. 现在有个周年庆宴会,宴会每邀请来一个职员都会 ...

  10. 【codevs1380】没有上司的舞会 树形dp

    题目描述 Ural大学有N个职员,编号为1~N.他们有从属关系,也就是说他们的关系就像一棵以校长为根的树,父结点就是子结点的直接上司.每个职员有一个快乐指数.现在有个周年庆宴会,要求与会职员的快乐指数 ...

随机推荐

  1. DMR windows 软件x64

    解压缩以后,默认使用串口4的USB热点板,用notepad2软件修改MMDVM.ini的呼号,ID,频率,串口号保存在打开DMR.bat即可,晶体有偏移的运行DMR500.bat https://sh ...

  2. STL常用序列容器

    这里简要的记述一下STL常用容器的实现原理,要点等内容. vector vector是比较常用的stl容器,用法与数组是非类似,其内部实现是连续空间分配,与数组的不同之处在于可弹性增加空间,而arra ...

  3. 一篇文章教会你用Python抓取抖音app热点数据

    今天给大家分享一篇简单的安卓app数据分析及抓取方法.以抖音为例,我们想要抓取抖音的热点榜数据. 要知道,这个数据是没有网页版的,只能从手机端下手. 首先我们要安装charles抓包APP数据,它是一 ...

  4. 没有国产主机,怎么开发:交叉编译和QEMU虚拟机

    1. 背景 近期国产化的趋势越来越浓,包括国产操作系统.国产CPU等.时隔十多年,QQ for Linux也更新了.做为软件开发人员,"有幸"也需要适配国产化.至于国产化的意义等就 ...

  5. 讨论session共享方案设计

    默认情况下,php的session文件是保存在磁盘文件中. 在php.ini配置文件中的配置项如下: session.save_handler = files session.save_path = ...

  6. Quartz.Net系列(三):解读Quartz.Net源码领略设计模式在其中的应用

    1.Builder(建造者)模式 JobBuilder  DateBuilder  其他的Builder(TriggerBuilder.SchedulerBuilder等) 2.抽象工厂模式 ISch ...

  7. animation 动画 与 transition

    animation: name duration timing-function delay iteration-count direction; 值 描述 animation-name 规定需要绑定 ...

  8. 使用Jmeter如何测试下载接口

    性能测试过程中,有时候需要对下载类的功能做压测,有些同学没有这方面的测试经验,比较迷茫,本文简单介绍下如何测试下载类的请求1.首先使用fiddler抓包,知道是一个http类型的请求,有一个post请 ...

  9. jmeter使用小结(一)

    jmeter是用来做接口压力测试的工具.这里只是简单介绍一下使用,大家可以自行查看帮助文档, 1.打开jmeter工具,创建线程组任务 2.添加配置元件,根据需要选择设置 3.添加采样器,这里是htt ...

  10. 入门大数据---通过Flume、Sqoop分析日志

    一.Flume安装 参考:Flume 简介及基本使用 二.Sqoop安装 参考:Sqoop简介与安装 三.Flume和Sqoop结合使用案例 日志分析系统整体架构图: 3.1配置nginx环境 请参考 ...