cf1153D 树形dp+思维
一千八的题也不会做了呜呜呜
size[u]表示结点u下的叶子结点,
思维:可以想到一个子树对其父亲会有一个消耗值
考虑一个点如果是max,那么其最大值可以是size[u]-p,p是消耗值最小的子树
一个点如果是min,那么其最大值是size[u]-所有子树的消耗值之和
那么dp[u]表示结点u的最大值为size[u]-dp[u]+1
dp[u]表示结点u的消耗值
叶子结点的消耗值为1,
max结点的消耗值为消耗值最小的子树
dp[u]=min(dp[v])
那么这个结点的结果是size[u]-dp[u]+1
min结点的消耗值为子树的消耗值之和dp[u]=sum(dp[v])
最后的答案是size[1]-dp[1]+1
#include<bits/stdc++.h>
using namespace std;
#define maxn 300005
struct Edge{int to,nxt;}edge[maxn<<];
int flag[maxn],a[maxn],head[maxn],tot,n;
void addedge(int u,int v){
edge[tot].to=v;edge[tot].nxt=head[u];head[u]=tot++;
}
void init(){
tot=;
memset(head,-,sizeof head);
}
int size[maxn];
void getsize(int u,int fa){
if(flag[u]==){size[u]=;return;}
for(int i=head[u];i!=-;i=edge[i].nxt){
int v=edge[i].to;
if(v==fa)continue;
getsize(v,u);
size[u]+=size[v];
}
}
int dp[maxn];
void dfs(int u,int fa){
if(flag[u]==){dp[u]=;return;}
int sum=,Min=0x3f3f3f3f;
for(int i=head[u];i!=-;i=edge[i].nxt){
int v=edge[i].to;
if(v==fa)continue;
dfs(v,u);
sum+=dp[v];
Min=min(Min,dp[v]);
}
if(a[u])dp[u]=Min;
else dp[u]=sum;
} int main(){
init();
cin>>n;
for(int i=;i<=n;i++)cin>>a[i];
for(int u=;u<=n;u++){
int fa;
cin>>fa;
flag[fa]=;
addedge(u,fa);
addedge(fa,u);
}
getsize(,);
dfs(,);
cout<<size[]-dp[]+<<endl;
}
cf1153D 树形dp+思维的更多相关文章
- Codeforces 1088E 树形dp+思维
比赛的时候看到题意没多想就放弃了.结果最后D也没做出来,还掉分了,所以还是题目做的太少,人太菜. 回到正题: 题意:一棵树,点带权值,然后求k个子连通块,使得k个连通块内所有的点权值相加作为分子除以k ...
- CF482D Random Function and Tree 树形DP + 思维 + 神题
Code: #include<bits/stdc++.h> #define ull unsigned long long #define MOD 1000000007 #define ll ...
- 【树形dp 思维题】HHHOJ#483. NOIP司马懿
要注意利用一些题目的特殊条件吧. 题目大意 有一颗$n$个点带点权$a_i$的树,$q$次询问树上是否存在长度为$l$的路径. $n,q,l\le 10^5,0 \le a_i \le 2$ 题目分析 ...
- 洛谷AT2046 Namori(思维,基环树,树形DP)
洛谷题目传送门 神仙思维题还是要写点东西才好. 树 每次操作把相邻且同色的点反色,直接这样思考会发现状态有很强的后效性,没办法考虑转移. 因为树是二分图,所以我们转化模型:在树的奇数层的所有点上都有一 ...
- HDU5758 Explorer Bo 思维+树形dp
题意自己看题目吧,挺短的. 思考过程:昨天感觉一天不做题很对不起自己,于是晚上跑到实验室打开别人树形dp的博客做了上面最后一个HDU的题,也是个多校题..一开始没有头绪了很久,因为起点不固定,所以这1 ...
- 宝藏(树形DP)
这道题目是十分考验思维的,n^2应该还是比较好想的,主要是如何转移根的问题.转移根,在我看来应该是树形dp最难的一部分了, 一般学会如何转移根,也就差不多考验通吃树形dp了. 下面转一转大佬链接: ...
- BZOJ5419[Noi2018]情报中心——线段树合并+虚树+树形DP
题目链接: [NOI2018]情报中心 题目大意:给出一棵n个节点的树,边有非负边权,并给出m条链,对于每条链有一个代价,要求选出两条有公共边的链使两条链的并的边权和-两条链的代价和最大. 花了一天的 ...
- cf796c 树形,思维题
一开始以为是个树形dp,特地去学了..结果是个思维题 /* 树结构,设最大点权值为Max,则答案必在在区间[Max,Max+2] 证明ans <= Max+2 任取一个点作为根节点,那么去掉这个 ...
- POJ 1849 - Two - [DFS][树形DP]
Time Limit: 1000MS Memory Limit: 30000K Description The city consists of intersections and streets t ...
随机推荐
- mybatis 使用缓存策略
mybatis中默认开启缓存 1.mybatis中,默认是开启缓存的,缓存的是一个statement对象. 不同情况下是否会使用缓存 同一个SqlSession对象,重复调用同一个id的<sel ...
- Mac之lnmp环境搭建
之前在Windows上开发大部分都是使用的集成环境(xampp,phpstudy,wamp),可以完成日常便捷开发,有些时候却Windows下无法实现的就需要自己搭建虚拟机,在虚拟机中搭建lnmp环境 ...
- opensetting禁用后小程序二次授权的问题-以及根据定位城市获取天气
一. 关于wx.openSetting 接口废弃后的通过其他方式重新设置权限的问题 最近小程序更新了后,导致以下报错 "openSetting:fail 此接口已废弃,请使用 OpenSet ...
- Sql JOIN 一张图说明
一图说明:
- Python开发第一篇
Python 是什么? 首先他可能是比较好的一个编程开发语言!
- Google Translation Via Python
没什么好说的,直接送包 https://github.com/mouuff/mtranslate
- codeforces660C
Hard Process CodeForces - 660C You are given an array a with n elements. Each element of a is either ...
- 爬虫免登录进入github
import requests import re ret = requests.get('https://github.com/login') print(ret.headers) cookies ...
- 数据分析之Matplotlib和机器学习基础
一.Matplotlib基础知识 Matplotlib 是一个 Python 的 2D绘图库,它以各种硬拷贝格式和跨平台的交互式环境生成出版质量级别的图形. 通过 Matplotlib,开发者可以仅需 ...
- Linux下C语言生成可执行文件的过程
在当前目录下创建一个C源文件并打开: touch test.c gedit test.c直接编译: gcc test.c -o test 分步骤编译: 1) 预处理 gcc -E test.c ...