A85657.Alice 的交通网络

普及+/提高

通过率:0%

时间限制:2.00s

内存限制:1024MB

题目描述

有一张由 nn 个据点组成的树形交通网。第 ii 个据点有正整数补给量 aia_i。你打算精确切断其中 kk 条边,把整张网络分成 k+1k+1 个独立区域。为了衡量“割裂代价”,我们定义每个区域的代价为该区域内补给量总和的平方;总目标是让所有区域代价之和尽可能小。

形式化地,切完后得到 k+1k+1 个连通块,其点权和分别为 s1,s2,,sk+1s_1,s_2,\dots,s_{k+1},则总代价为

Cost=i=1k+1si2.\mathrm{Cost}=\sum_{i=1}^{k+1} s_i^2 .

请输出可达到的最小代价。

输入格式

  • 第一行两个整数 n,kn,k
  • 第二行 nn 个整数 a1,a2,,ana_1,a_2,\dots,a_n
  • 接下来 n1n-1 行,每行两个整数 u,vu,v,表示无向边 (u,v)(u,v),保证这些边构成一棵树。

输出格式

输出一个整数,表示最小可能的总代价。

输入输出样例

  • 输入#1

    5 1
    1 2 3 4 5
    1 2
    2 3
    3 4
    4 5
    

    输出#1

    117
    
  • 输入#2

    6 2
    2 2 3 2 1 2
    1 2
    2 3
    3 4
    4 5
    5 6
    

    输出#2

    50
    

说明/提示

  • 1n5×1031\le n\le 5\times 10^3
  • 0kmin{30,n1}0\le k\le \min\{30,n-1\}
  • 1ai1041\le a_i\le 10^4
  • 1u,vn1\le u,v\le n,给出的 n1n-1 条边保证构成一棵树
首页