BZOJ[3252]攻略(长链剖分)
2024-08-30 02:08:42
BZOJ[3252]攻略
Description
题目简述:树版[k取方格数]
众所周知,桂木桂马是攻略之神,开启攻略之神模式后,他可以同时攻略k部游戏。今天他得到了一款新游戏《XX半岛》,这款游戏有n个场景(scene),某些场景可以通过不同的选择支到达其他场景。所有场景和选择支构成树状结构:开始游戏时在根节点(共通线),叶子节点为结局。每个场景有一个价值,现在桂马开启攻略之神模式,同时攻略k次该游戏,问他观赏到的场景的价值和最大是多少(同一场景观看多次是不能重复得到价值的)
“为什么你还没玩就知道每个场景的价值呢?”
“我已经看到结局了。”
Input
第一行两个正整数n,k
第二行n个正整数,表示每个场景的价值
以下n-1行,每行2个整数a,b,表示a场景有个选择支通向b场景(即a是b的父亲)
保证场景1为根节点
n<=200000,1<=场景价值<=2^31-1
Output
输出一个整数表示答案
Sample Input
5 2
4 3 2 1 1
1 2
1 5
2 3
2 4
Sample Output
10
一个类似长链剖分的东西。
直接把链按照权值剖分,取前k个最长的链
#include<bits/stdc++.h>
#define lll long long
using namespace std;
lll read(){
lll x=0,w=1;char ch=getchar();
while(ch>'9'||ch<'0'){if(ch=='-')w=-1;ch=getchar();}
while(ch>='0'&&ch<='9') x=(x<<3)+(x<<1)+ch-'0',ch=getchar();
return x*w;
}
const lll N=200010;
lll n,k,cnt,opt,ans,x,y;
lll a[N],head[N],son[N],sum[N],c[N];
struct node{
lll to,next;
}edge[N];
bool cmp(lll p,lll q){return p>q;}
void add(lll x,lll y){
cnt++;edge[cnt].to=y;edge[cnt].next=head[x];head[x]=cnt;
}
void dfs1(lll k){
for(lll i=head[k];i;i=edge[i].next){
lll v=edge[i].to;dfs1(v);
sum[k]=max(sum[k],sum[v]);if(sum[v]>sum[son[k]])son[k]=v;
}sum[k]+=a[k];
}
void dfs2(lll k,lll top){
if(k==top)c[++opt]=sum[k];
if(!son[k])return;
dfs2(son[k],top);
for(lll i=head[k];i;i=edge[i].next){
lll v=edge[i].to;if(v==son[k])continue;
dfs2(v,v);
}
}
int main(){
n=read();k=read();
for(lll i=1;i<=n;i++)a[i]=read();
for(lll i=1;i<n;i++){
x=read();y=read();add(x,y);
}dfs1(1);dfs2(1,1);sort(c+1,c+1+opt,cmp);
for(lll i=1;i<=k;i++)ans+=c[i];
printf("%lld\n",ans);return 0;
}
最新文章
- 设置DataSource后DateGridView不显示的问题
- C#动手实践:Kinect V2 开发(2):数据源工作原理及红外源Demo
- Android中的Binder机制的简要理解
- joomla allvideo 去掉embed share
- 【PRML读书笔记-Chapter1-Introduction】1.6 Information Theory
- 我的android学习经历14
- 合理利用 vs2013的性能分析跟诊断
- unresolved external symbol ";public: virtual __thiscall...错误
- 火狐浏览器设置placeholder的时候记得改opacity
- 单独调用Ueditor的图片上传功能
- ZOJ 1301 The New Villa (BFS + 状态压缩)
- 使用__doPostBack函数来达到使用客户端的控件来调用服务器端的函数的--小结
- Mac OS X 下修改网卡地址和抵御 ARP 攻击
- Neutron 不健全的HA ROUTER
- robotium问答
- 深入理解php内核 编写扩展_III- 资源
- css3 动画 总结
- Python re.findall函数不能匹配但是notepad++能匹配
- 容器启动报iptables错误
- 用Msxml2.XMLHTTP 与 Msxml2.ServerXMLHTTP 发生网页请求
热门文章
- 阶段3 2.Spring_09.JdbcTemplate的基本使用_2 JdbcTemplate的概述和入门
- Stream流实现斐波那契数列
- js获取当天时间,7天前后时间,时间格式化
- cocos2dx基础篇(2) 第一个程序
- USACO4.3 Street Race【分析】
- v-if 和v-show的区别
- 红帽学习记录[RHCE] ISCSI远程块储存
- Vmware ESXI 安装Windows
- Luogu P1450 [HAOI2008]硬币购物
- 前端技术之:如何Mock GraphQL接口数据