#251. 医院设置

医院设置

题目描述

设有一棵二叉树,如图:

图中,圈中的数字表示结点中居民的人口,圈边上数字表示结点编号。现在要求在某个结点上建立一个医院,使所有居民所走的路程之和为最小。相邻结点之间的距离为 11

例如上图中:

  • 若医院建在 11 处,则距离和 =4+12+2×20+2×40=136= 4 + 12 + 2 \times 20 + 2 \times 40 = 136
  • 若医院建在 33 处,则距离和 =4×2+13+20+40=81= 4 \times 2 + 13 + 20 + 40 = 81

输入格式

第一行一个整数 nn,表示树的结点数(结点编号为 11nn)。

接下来 nn 行,每行三个整数 w,u,vw, u, v,分别表示该结点的居民人口数、左儿子编号、右儿子编号(00 表示不存在)。

输出格式

一个整数,表示最小距离和。

5
13 2 3
4 0 0
12 4 5
20 0 0
40 0 0
81

数据规模与约定

对于全部的测试点,保证 1n1001 \leq n \leq 1001w1051 \leq w \leq 10^50u,vn0 \leq u, v \leq n