#O3813. LQ.蓝桥杯.十五届.国赛.编程题.06.道路监控

LQ.蓝桥杯.十五届.国赛.编程题.06.道路监控

问题描述

某城市的道路构成了一个巨大的树形结构,每一条道路可视为该结构的一条边,而道路的交叉点或端点视为其中的一个节点。该城市共有 nn 个节点,编号分别为 123...n1、2、3、... n。为了实时记录道路情况,需要在某些节点部署监控设备,当部署好后,与该节点直接相连的所有道路均能被监控到。

为了优化资源分配,在保证整座城市的所有道路都被监控到的前提下,部署监控设备的费用要尽可能少。

给定每个节点部署监控设备的费用,请计算要使所有道路都能被监控到的最少花费是多少?

例如: n=8,表示有 8 个节点(即道路交叉点或端点),1 到 8 号节点部署监控设备的费用分别为 33、12、30、22、18、10、31、28。道路分布图如下:

monitor

根据观察可得,在 2 号和 3 号节点处部署监控设备,可以使所有道路都能被监控到,并且花费最少最少花费为 42 。

输入描述

第一行输入一个整数 nn( 2n1042 \le n \le 10^4 ),表示城市中节点(即道路交 叉点或端点)的数量

第二行输入 nn 个整数( 1<1 \lt 整数 105 \le 10^5 ),分别表示 11 号到 nn 号节 点部署监控设备的费用

接下来 n1n-1 行,每行输入两个整数 aabb,表示节点 aa 和节点 bb 之间有一条道路

输出描述

输出一个整数,表示要使所有道路均能被监控到的最少花费。

样例

8
33 12 30 22 18 10 31 28
1 2
1 3
2 4
2 5
2 6
3 7
3 8
42