BZOJ 1827: [Usaco2010 Mar]gather 奶牛大集会 树形DP + 带权重心
Description
Input
Output
#include <bits/stdc++.h>
#define setIO(s) freopen(s".in","r",stdin)
#define maxn 1000000
#define inf 100000000000000
#define ll long long
using namespace std;
ll f[maxn], siz[maxn], sumv[maxn];
int C[maxn], hd[maxn], to[maxn << 1], nex[maxn << 1], val[maxn << 1];
int n, edges, root;
ll tot;
void add(int u, int v, int c)
{nex[++edges] = hd[u], hd[u] = edges, to[edges] = v, val[edges] = c;
}
void dfs(int u, int ff)
{siz[u] = C[u], f[u] = 0; for(int i = hd[u]; i ; i = nex[i]) {int v = to[i]; if(v == ff) continue; dfs(v, u); siz[u] += siz[v];f[u] = max(f[u], siz[v]); } f[u] = max(f[u], tot - siz[u]); if(f[u] < f[root]) root = u;
}
void calc(int u,int ff)
{siz[u] = C[u], sumv[u] = 0; for(int i = hd[u]; i ; i = nex[i]){int v = to[i]; if(v == ff) continue; calc(v, u); siz[u] += siz[v]; sumv[u] += sumv[v] + val[i] * siz[v]; }
}
int main()
{// setIO("input"); scanf("%d",&n); for(int i = 1; i <= n; ++i) scanf("%d",&C[i]), tot += C[i]; for(int i = 1, u, v, c; i < n; ++i) {scanf("%d%d%d",&u,&v,&c); add(u, v, c); add(v, u, c); }f[0] = inf, root = 0, dfs(1, 0);memset(siz, 0, sizeof(siz)), calc(root, 0); printf("%lld\n",sumv[root]); return 0;
}
转载于:https://www.cnblogs.com/guangheli/p/10982700.html
BZOJ 1827: [Usaco2010 Mar]gather 奶牛大集会 树形DP + 带权重心相关推荐
- BZOJ 1827: [Usaco2010 Mar]gather 奶牛大集会 树形DP
[Usaco2010 Mar]gather 奶牛大集会 Bessie正在计划一年一度的奶牛大集会,来自全国各地的奶牛将来参加这一次集会.当然,她会选择最方便的地点来举办这次集会.每个奶牛居住在 N(1 ...
- bzoj 1827: [Usaco2010 Mar]gather 奶牛大集会【树形dp】
不能用read会TLE!!不能用read会TLE!!不能用read会TLE!! 一开始以为要维护每个点,线段树写了好长(还T了-- 首先dfs一遍,求出点1为集会地点的答案,处理处val[u]为以1为 ...
- [Usaco2010 Mar]gather 奶牛大集会
1827: [Usaco2010 Mar]gather 奶牛大集会 Time Limit: 1 Sec Memory Limit: 64 MB Submit: 1129 Solved: 525 [ ...
- bzoj 1657: [Usaco2006 Mar]Mooo 奶牛的歌声(单调栈)
1657: [Usaco2006 Mar]Mooo 奶牛的歌声 Time Limit: 5 Sec Memory Limit: 64 MB Submit: 848 Solved: 594 [Sub ...
- BZOJ 2097 [Usaco2010 Dec]Exercise 奶牛健美操
[题意] 给出一棵树.现在可以在树中删去m条边,使它变成m+1棵树.要求最小化树的直径的最大值. [题解] 二分答案.$Check$的时候用$DP$,记录当前节点每个儿子的直径$v[i]$,如果$v[ ...
- BZOJ 1779. [Usaco2010 Hol]Cowwar 奶牛战争
传送门 考虑构建网络流模型 把一个流量看成一只奶牛的攻击过程,那么答案就是最大流 因为每只奶牛只能操作一波,所以构造分层图,一层相当于一步 第一层就是初始状态,从 $S$ 向所有 $J$ 奶牛连一条流 ...
- BZOJ 1829 [Usaco2010 Mar]starc星际争霸 ——半平面交
发现最终的结果只和$s1$,$s2$,$s3$之间的比例有关. 所以直接令$s3=1$ 然后就变成了两个变量,然后求一次半平面交. 对于每一个询问所属的直线,看看半平面在它的那一侧,或者相交就可以判断 ...
- bzoj 1617: [Usaco2008 Mar]River Crossing渡河问题(DP)
1617: [Usaco2008 Mar]River Crossing渡河问题 Time Limit: 5 Sec Memory Limit: 64 MB Submit: 1077 Solved: ...
- bzoj 1597: [Usaco2008 Mar]土地购买(斜率优化dp 例题)
Description 农夫John准备扩大他的农场,他正在考虑N (1 <= N <= 50,000) 块长方形的土地. 每块土地的长宽满足(1 <= 宽 <= 1,000, ...
最新文章
- C# 简单软件有效期注册的实现【原】
- Handler消息机制(六):Looper.loop()为什么不会阻塞主线程?
- javascript DOM innerHTML createElement createTextNode
- matlab clabel函数用法,CLabel的用法 | 学步园
- hdu 1528+hdu 1962(最小覆盖)
- 微信小程序学习笔记(六)
- django分页功能
- 数据结构和算法基础之冒泡排序
- osgi框架 android,基于OSGi的Android应用模块动态加载框架设计与实现
- linux+系统优化基础,Linux入门基础(三):Linux用户及权限基础
- 网易java默认路径_java对象存储位置
- 关闭Xcode警告 (强迫症还在等什么!)
- 广东哪所大学计算机专业好,准备考研,广东哪所大学的计算机专业最好?除了985,这所大学性价比很高...
- 【Oracle】DataGuard中 Switchover 主、备切换
- Python_随机生成11位手机号
- ODAC Windows 安装
- Anaconda报错:Conda SSL Error: OpenSSL appears to be unavailable on this machine. OpenSSL is required t
- kicad最小布线宽度默认是多少_常见停车场管理系统项目的安装布线及注意事项...
- mysql mtq_mysql高级复习 - osc_r3mtqivi的个人空间 - OSCHINA - 中文开源技术交流社区
- 2021年全国职业院校技能大赛 “大数据技术与应用”—模拟赛题(三)