#P9476. [_-0 B] 地铁

    ID: 8712 Type: RemoteJudge 1000ms 128MiB Tried: 0 Accepted: 0 Difficulty: 6 Uploaded By: Tags>O2优化斜率优化树形 dp树的直径

[_-0 B] 地铁

题目背景

f\mathfrak{f} 的家乡 A 市最近开通了地铁。

题目描述

A 市共有 n(2n105)n (2\le n \le 10^5) 个居民点,第 ii 个居民点的人口为 si(1si107)s_i (1 \le s_i \le 10^7),同时有 n1n-1 条双向道路,构成一棵树,第 ii 条双向道路连接居民点 uiu_iviv_i,人步行走过这条道路需要 wi(1wi107)w_i (1 \le w_i\le 10^7) 的时间。

现 A 市政府决定开通一条地铁线路。地铁线路是树上的一条简单路径,若路径经过第 ii 条道路,那么地铁从这条道路下方经过只需要 wi(1wi107)w_i^{\prime} (1 \le w_i^{\prime} \le 10^7) 的时间,同时,地铁的进出站需要花费 t(0t107)t (0 \le t \le 10^7) 的时间。

已知,若一个人从一个居民点前往另一个居民点,如果这条路径与地铁经过的路径有至少一条公共,那么就一定会选择尽可能多地乘坐地铁。如果没有公共边,那么就会选择完全步行。题目保证对于第 ii 条道路有 wiwitw_i^{\prime} \le w_i - t 我们认为,如果两个居民点的人口的乘积越大,那么有人想要在它们之间流动的可能性也越大。

现在,小 f\mathfrak{f} 想知道在所有 n(n1)2\frac{n(n-1)}{2} 种建造地铁线路的方案中,$\sum_{a=1}^{n-1}\sum_{b=a+1}^{n}(s_a \cdot s_b \cdot d_{a,b})$ 的最小值,其中 da,bd_{a,b} 表示从居民点 aa 前往 bb(或者从 bb 前往 aa,两者是相等的)所需要的时间。

但是他不会,所以他来求助万能的你。

输入格式

第一行,三个用空格分隔的整数 id,n,tid,n,t,表示子任务编号,居民点个数和进出站所需要花费的时间。

接下来 nn 行,每行一个整数 sis_i,表示每个居民点的人口。

接下来 n1n - 1 行,每行四个用空格分隔的整数 ui,vi,wi,wiu_i,v_i,w_i,w_i^{\prime},表示每条道路的两个端点,步行所需时间和地铁所需时间。

输出格式

一行,一个整数,表示所求的最小值。

答案可能超过 6464 位整形表示范围,您可以使用 __int128 类型,其表示范围为 [2127,21271][-2^{127},2^{127}-1]

以下为 __int128 类型的输出模板:

#include <bits/stdc++.h>
using namespace std;
__int128 ans;
int main() {
    /* Your code here */
    string str;
    if (!ans) {
        str = "0";
    } else {
        str = "";
        while (ans) {
            str = ((char)(48 + ans % 10)) + str;
            ans /= 10;
        }
    }
    cout << str << endl;
    return 0;
}
0 5 0
9
9
3
2
3
1 2 7 6
1 3 8 5
1 4 6 5
2 5 9 9
2262
0 10 86
50
6
84
50
83
67
93
55
93
70
1 2 94 7
1 3 97 4
1 10 98 12
2 4 89 1
2 7 98 1
4 5 99 13
4 6 96 5
5 8 95 5
5 9 97 7
33600416

提示

样例 11 解释:

修建地铁前如下图所示:

一种最优的修建地铁的方案为从 2233 修建地铁。如下图所示(实线表示修建了地铁):

1122 经过地铁,所需时间为:6+0=66+0=6,对答案的贡献为:9×9×6=4869\times9\times6=486

1133 经过地铁,所需时间为:5+0=55+0=5,对答案的贡献为:9×3×5=1359\times3\times5=135

1144 不经过地铁,所需时间为:66,对答案的贡献为:9×2×6=1089\times2\times6=108

1155 经过地铁,所需时间为:6+9+0=156+9+0=15,对答案的贡献为:9×3×15=4059\times3\times15=405

2233 经过地铁,所需时间为:6+5+0=116+5+0=11,对答案的贡献为:9×3×11=2979\times3\times11=297

2244 经过地铁,所需时间为:6+6+0=126+6+0=12,对答案的贡献为:9×2×12=2169\times2\times12=216

2255 不经过地铁,所需时间为:99,对答案的贡献为:9×3×9=2439\times3\times9=243

3344 经过地铁,所需时间为:5+6+0=115+6+0=11,对答案的贡献为:3×2×11=663\times2\times11=66

3355 经过地铁,所需时间为:5+6+9+0=205+6+9+0=20,对答案的贡献为:3×3×20=1803\times3\times20=180

4455 经过地铁,所需时间为:6+6+9+0=216+6+9+0=21,对答案的贡献为:2×3×21=1262\times3\times21=126

综上,答案为:486+135+108+405+297+216+243+66+180+126=2262486+135+108+405+297+216+243+66+180+126=2262

可以证明不存在更优的修建地铁的方案。

本题采用捆绑测试且使用子任务依赖。

编号 分值 nn \le 性质 依赖
00 N/A 样例
11 55 1010
22 500500 11
33 1010 50005000 1,21,2
44 3030 10510^5 A
55 B
66 2020 C
77 1515 D
88 1010 0,1,2,3,4,5,6,70,1,2,3,4,5,6,7

特殊性质 A:t=0t=0

特殊性质 B:ui=i,vi=i+1u_i=i,v_i=i+1

特殊性质 C:每一个点的度数都不超过 100100

特殊性质 D:ui=1,vi=i+1u_i=1,v_i=i+1