美团2017年CodeM大赛-初赛B轮-黑白树
https://ac.nowcoder.com/acm/problem/13249
链接:https://ac.nowcoder.com/acm/problem/13249
来源:牛客网
题目描述
你需要通过一系列操作使得最终每个点变成黑色。每次操作需要选择一个节点i,i必须是白色的,然后i到根的链上(包括节点i与根)所有与节点i距离小于k[i]的点都会变黑,已经是黑的点保持为黑。问最少使用几次操作能把整棵树变黑。
输入描述:
第一行一个整数n (1 ≤ n ≤ 10^5)
接下来n-1行,每行一个整数,依次为2号点到n号点父亲的编号。
最后一行n个整数为k[i] (1 ≤ k[i] ≤ 10^5) 样例解释:
对节点3操作,导致节点2与节点3变黑
对节点4操作,导致节点4变黑
对节点1操作,导致节点1变黑
输出描述:
一个数表示最少操作次数
输出
3
叶子节点一定要染色,边界确定。维护三个变量f[u][0/1/2],一个是以当前节点为根的子树花费的最小染色次数,一个
是对已经染色的子节点点来说,最长的染色距离,还有一个就是对于所有子节点来说最长的染色距离。
如果f[u][1]能到达当前节点可以不必染当前点,如果到不了就买f[u][2]的那个点,因为他是最优的,顺便更新下f[u][1]。
#include<bits/stdc++.h>
using namespace std;
#define LL long long const int maxn=;
vector<int>g[maxn];
int n,f[maxn][],c[maxn];
void dfs(int u,int dep){
if(g[u].size()==){
f[u][]=;
f[u][]=c[u]; //买
f[u][]=c[u]; //all
return;
}
f[u][]=;
f[u][]=c[u];
for(auto v:g[u]){
dfs(v,dep+);
f[u][]+=f[v][];
f[u][]=max(f[u][],f[v][]-);
f[u][]=max(f[u][],f[v][]-);
}
if(f[u][]<=){
f[u][]++;
f[u][]=f[u][];
}
}
int main(){
int fa;
cin>>n;
for(int i=;i<=n;++i){
cin>>fa;
g[fa].push_back(i);
}
for(int i=;i<=n;++i)cin>>c[i];
dfs(,);
cout<<f[][];
return ;
}
美团2017年CodeM大赛-初赛B轮-黑白树的更多相关文章
- 美团2017年CodeM大赛-初赛B轮 黑白树 (树形dp)
		大意: 给定树, 初始每个点全为白色, 点$i$有权值$k_i$, 表示选择$i$后, 所有距离$i$小于$k_i$的祖先(包括i)会变为黑色, 求最少选多少个点能使所有点变为黑色. 链上情况的话, ... 
- 美团2017年CodeM大赛-初赛A轮 C合并回文子串
		区间dp一直写的是递归版本的, 竟然超时了, 学了一下非递归的写法. #include <iostream> #include <sstream> #include <a ... 
- 美团2018年CodeM大赛-初赛B轮 B 配送(最短路)
		美团2018年CodeM大赛-初赛B轮 B 配送 题意 题解 对于每个任务,只要从上个任务的终点出发即可. 时间.地点很少,可以算出每个地点-时间的最小花费. 以题目描述的起点终点起始结束时间建图,很 ... 
- CodeM美团点评编程大赛初赛B轮 黑白树【DFS深搜+暴力】
		[编程题] 黑白树 时间限制:1秒 空间限制:32768K 一棵n个点的有根树,1号点为根,相邻的两个节点之间的距离为1.树上每个节点i对应一个值k[i].每个点都有一个颜色,初始的时候所有点都是白色 ... 
- 美团2018年CodeM大赛-初赛B轮 C题低位值
		试题链接:https://www.nowcoder.com/acm/contest/151/C 定义lowbit(x) =x&(-x),即2^(p-1) (其中p为x的二进制表示中,从右向左数 ... 
- CodeM美团点评编程大赛初赛A轮
		因为语文太差弃赛,第一个追及问题看不懂我就弃赛了.打进复赛确实挺难的,补一下题,锻炼下就行了. 身体训练 时间限制:1秒 空间限制:32768K 美团外卖的配送员用变速跑的方式进行身体训练.他们训练的 ... 
- 2018美团CodeM编程大赛初赛B轮 A题开关灯
		题目描述 美团的办公室一共有n层,每层有m个会议室,可以看成是一个n*m的网格图.工程师们每天的工作需要协作的地方很多,经常要到会议室开会解决各种问题.公司是提倡勤俭节约的,因此每次会议室只在使用时才 ... 
- codeM美团编程大赛初赛B轮D题
		[编程题] 模 时间限制:1秒空间限制:32768K 给定四个正整数a,b,c,k,回答是否存在一个正整数n,使得a*n在k进制表示下的各位的数值之和模b为c.输入描述:第一行一个整数T(T < ... 
- codeM美团编程大赛初赛B轮E题
		题目描述 给出一个正整数n,我们把1..n在k进制下的表示连起来记为s(n,k),例如s(16,16)=123456789ABCDEF10, s(5,2)=11011100101.现在对于给定的n和字 ... 
随机推荐
- setoolkit 制作钓鱼网页
			由于是在虚拟机下实验,仅做示范 下载地址 git clone https://github.com/trustedsec/social-engineer-toolkit/ 终端输入setoolkit启 ... 
- 打造RecyclerView的n级列表
			先上效果图: 1.该多级列表的优势: 支持无限级列表展开 基于一个recyclerView实现 可以自定义每一级item的样式,定制化更强 2.设计的思路 数据结构List,ItemBean类中有变量 ... 
- MyBatis探究-----核心配置文件mybatis-config.xml中配置mappers的几种方式
			1.package name="映射文件所在包名" 必须保证接口名(例如IUserDao)和xml名(IUserDao.xml)相同,还必须在同一个包中 例如:<packag ... 
- mysql 事物没提交导致事物一直运行解决方案
			1.设置 innodb_kill_idle_transaction 参数, 可以永久避免 https://dbaplus.cn/news-11-974-1.html 
- python———day1
			1.计算机基础:CPU,内存,硬盘,操作系统 2.python出生于应用 3.python2与python3的区别(宏观): python2:源码不标准,混乱,重复代码太多 python3:统一标准, ... 
- 2019/4/19 wen 线程2
- flutter -icons
			icon 合集 https://material.io/tools/icons/?icon=account_balance&style=baseline 
- CentOS 7离线安装CDH 5.16.1完全指南(含各种错误处理)
			安装包下载 1.CM软件包下载 从http://archive.cloudera.com/cm5/redhat/7/x86_64/cm/5.16.1/RPMS/x86_64/下载rpm包,如下: 其实 ... 
- linux 安装oracle
			报错1:报display相关错误su - oracleDISPLAY=redhat64-2:1 --此处为远程会话地址(可以写localhost或IP均可)export DISPLAYcd /home ... 
- mfc双缓冲绘图
			1.要求 在界面加载本地图片并显示,每过100ms改变一张图片显示 2.现象 通过定时器控制CImage,Load,Draw,Destroy,会非常的卡顿.因为Load图片时,会是非常大的数据[所有C ... 
