CF1092F.Tree with Maximum Cost
普及/提高-
通过率:0%
AC君温馨提醒
该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。
题目描述
You are given a tree consisting exactly of n vertices. Tree is a connected undirected graph with n−1 edges. Each vertex v of this tree has a value av assigned to it.
Let dist(x,y) be the distance between the vertices x and y . The distance between the vertices is the number of edges on the simple path between them.
Let's define the cost of the tree as the following value: firstly, let's fix some vertex of the tree. Let it be v . Then the cost of the tree is i=1∑ndist(i,v)⋅ai .
Your task is to calculate the maximum possible cost of the tree if you can choose v arbitrarily.
输入格式
The first line contains one integer n , the number of vertices in the tree ( 1≤n≤2⋅105 ).
The second line of the input contains n integers a1,a2,…,an ( 1≤ai≤2⋅105 ), where ai is the value of the vertex i .
Each of the next n−1 lines describes an edge of the tree. Edge i is denoted by two integers ui and vi , the labels of vertices it connects ( 1≤ui,vi≤n , ui=vi ).
It is guaranteed that the given edges form a tree.
输出格式
Print one integer — the maximum possible cost of the tree if you can choose any vertex as v .
输入输出样例
输入#1
8 9 4 1 7 10 1 6 5 1 2 2 3 1 4 1 5 5 6 5 7 5 8
输出#1
121
输入#2
1 1337
输出#2
0
说明/提示
Picture corresponding to the first example:
You can choose the vertex 3 as a root, then the answer will be 2⋅9+1⋅4+0⋅1+3⋅7+3⋅10+4⋅1+4⋅6+4⋅5=18+4+0+21+30+4+24+20=121 .
In the second example tree consists only of one vertex so the answer is always 0 .