Description

Bessie正在计划一年一度的奶牛大集会,来自全国各地的奶牛将来参加这一次集会。当然,她会选择最方便的地点来举办这次集会。每个奶牛居住在 N(1<=N<=100,000) 个农场中的一个,这些农场由N-1条道路连接,并且从任意一个农场都能够到达另外一个农场。道路i连接农场A_i和B_i(1 <= A_i <=N; 1 <= B_i <= N),长度为L_i(1 <= L_i <= 1,000)。集会可以在N个农场中的任意一个举行。另外,每个牛棚中居住者C_i(0 <= C_i <= 1,000)只奶牛。在选择集会的地点的时候,Bessie希望最大化方便的程度(也就是最小化不方便程度)。比如选择第X个农场作为集会地点,它的不方便程度是其它牛棚中每只奶牛去参加集会所走的路程之和,(比如,农场i到达农场X的距离是20,那么总路程就是C_i*20)。帮助Bessie找出最方便的地点来举行大集会。 考虑一个由五个农场组成的国家,分别由长度各异的道路连接起来。在所有农场中,3号和4号没有奶牛居住。

Input

第一行:一个整数N * 第二到N+1行:第i+1行有一个整数C_i * 第N+2行到2*N行,第i+N+1行为3个整数:A_i,B_i和L_i。

Output

* 第一行:一个值,表示最小的不方便值。
题解:不难发现选定点必须是树的带权重心 (任意儿子大小不能超过总和一半). 
直接 DFS 求重心并算一下贡献即可. 
#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 + 带权重心相关推荐

  1. BZOJ 1827: [Usaco2010 Mar]gather 奶牛大集会 树形DP

    [Usaco2010 Mar]gather 奶牛大集会 Bessie正在计划一年一度的奶牛大集会,来自全国各地的奶牛将来参加这一次集会.当然,她会选择最方便的地点来举办这次集会.每个奶牛居住在 N(1 ...

  2. bzoj 1827: [Usaco2010 Mar]gather 奶牛大集会【树形dp】

    不能用read会TLE!!不能用read会TLE!!不能用read会TLE!! 一开始以为要维护每个点,线段树写了好长(还T了-- 首先dfs一遍,求出点1为集会地点的答案,处理处val[u]为以1为 ...

  3. [Usaco2010 Mar]gather 奶牛大集会

    1827: [Usaco2010 Mar]gather 奶牛大集会 Time Limit: 1 Sec  Memory Limit: 64 MB Submit: 1129  Solved: 525 [ ...

  4. bzoj 1657: [Usaco2006 Mar]Mooo 奶牛的歌声(单调栈)

    1657: [Usaco2006 Mar]Mooo 奶牛的歌声 Time Limit: 5 Sec  Memory Limit: 64 MB Submit: 848  Solved: 594 [Sub ...

  5. BZOJ 2097 [Usaco2010 Dec]Exercise 奶牛健美操

    [题意] 给出一棵树.现在可以在树中删去m条边,使它变成m+1棵树.要求最小化树的直径的最大值. [题解] 二分答案.$Check$的时候用$DP$,记录当前节点每个儿子的直径$v[i]$,如果$v[ ...

  6. BZOJ 1779. [Usaco2010 Hol]Cowwar 奶牛战争

    传送门 考虑构建网络流模型 把一个流量看成一只奶牛的攻击过程,那么答案就是最大流 因为每只奶牛只能操作一波,所以构造分层图,一层相当于一步 第一层就是初始状态,从 $S$ 向所有 $J$ 奶牛连一条流 ...

  7. BZOJ 1829 [Usaco2010 Mar]starc星际争霸 ——半平面交

    发现最终的结果只和$s1$,$s2$,$s3$之间的比例有关. 所以直接令$s3=1$ 然后就变成了两个变量,然后求一次半平面交. 对于每一个询问所属的直线,看看半平面在它的那一侧,或者相交就可以判断 ...

  8. bzoj 1617: [Usaco2008 Mar]River Crossing渡河问题(DP)

    1617: [Usaco2008 Mar]River Crossing渡河问题 Time Limit: 5 Sec  Memory Limit: 64 MB Submit: 1077  Solved: ...

  9. bzoj 1597: [Usaco2008 Mar]土地购买(斜率优化dp 例题)

    Description 农夫John准备扩大他的农场,他正在考虑N (1 <= N <= 50,000) 块长方形的土地. 每块土地的长宽满足(1 <= 宽 <= 1,000, ...

最新文章

  1. C# 简单软件有效期注册的实现【原】
  2. Handler消息机制(六):Looper.loop()为什么不会阻塞主线程?
  3. javascript DOM innerHTML createElement createTextNode
  4. matlab clabel函数用法,CLabel的用法 | 学步园
  5. hdu 1528+hdu 1962(最小覆盖)
  6. 微信小程序学习笔记(六)
  7. django分页功能
  8. 数据结构和算法基础之冒泡排序
  9. osgi框架 android,基于OSGi的Android应用模块动态加载框架设计与实现
  10. linux+系统优化基础,Linux入门基础(三):Linux用户及权限基础
  11. 网易java默认路径_java对象存储位置
  12. 关闭Xcode警告 (强迫症还在等什么!)
  13. 广东哪所大学计算机专业好,准备考研,广东哪所大学的计算机专业最好?除了985,这所大学性价比很高...
  14. 【Oracle】DataGuard中 Switchover 主、备切换
  15. Python_随机生成11位手机号
  16. ODAC Windows 安装
  17. Anaconda报错:Conda SSL Error: OpenSSL appears to be unavailable on this machine. OpenSSL is required t
  18. kicad最小布线宽度默认是多少_常见停车场管理系统项目的安装布线及注意事项...
  19. mysql mtq_mysql高级复习 - osc_r3mtqivi的个人空间 - OSCHINA - 中文开源技术交流社区
  20. 2021年全国职业院校技能大赛 “大数据技术与应用”—模拟赛题(三)

热门文章

  1. java学习(60):java最终类(了解)
  2. CSS Grid布局(1)
  3. 搜索和在线阅读 Github 代码的插件推荐
  4. springboot 获取控制器参数的几种方式
  5. vue之watch用法
  6. Page Cache的落地问题
  7. 部署项目到jetty
  8. 使多个线程循环输出0-99-0-99
  9. rsync 服务快速部署手册
  10. ADO连接各种数据库