P2052 [NOI2011] 道路修建
题目描述
在 W 星球上有 nnn 个国家。为了各自国家的经济发展,他们决定在各个国家之间建设双向道路使得国家之间连通。但是每个国家的国王都很吝啬,他们只愿意修建恰好 n−1n - 1n−1 条双向道路。
每条道路的修建都要付出一定的费用,这个费用等于道路长度乘以道路两端 的国家个数之差的绝对值。例如,在下图中,虚线所示道路两端分别有 222 个、444 个国家,如果该道路长度为 111,则费用为 1×∣2−4∣=21×|2 - 4|=21×∣2−4∣=2。图中圆圈里的数字表示国家的编号。

由于国家的数量十分庞大,道路的建造方案有很多种,同时每种方案的修建费用难以用人工计算,国王们决定找人设计一个软件,对于给定的建造方案,计算出所需要的费用。请你帮助国王们设计一个这样的软件。
输入格式
输入的第一行包含一个整数 nnn,表示 W 星球上的国家的数量,国家从 111 到 nnn 编号。
接下来 n–1n–1n–1 行描述道路建设情况,其中第 iii 行包含三个整数 ai,bia_i,b_iai,bi 和 cic_ici,表示第 iii 条双向道路修建在 aia_iai 与 bib_ibi 两个国家之间,长度为 cic_ici。
输出格式
输出一个整数,表示修建所有道路所需要的总费用。
输入输出样例 #1
输入 #1
6
1 2 1
1 3 1
1 4 2
6 3 1
5 2 1
输出 #1
20
说明/提示
对于 100%100\%100% 的数据,1≤ai,bi≤n1\leq a_i, b_i\leq n1≤ai,bi≤n,0≤ci≤1060\leq c_i\leq10^60≤ci≤106,2≤n≤1062\leq n\leq 10^62≤n≤106。
| 测试点编号 | n=n=n= |
|---|---|
| 111 | 222 |
| 222 | 101010 |
| 333 | 100100100 |
| 444 | 200200200 |
| 555 | 500500500 |
| 666 | 600600600 |
| 777 | 800800800 |
| 888 | 100010001000 |
| 999 | 10410^4104 |
| 101010 | 2×1042\times 10^42×104 |
| 111111 | 5×1045\times 10^45×104 |
| 121212 | 6×1046\times 10^46×104 |
| 131313 | 8×1048\times 10^48×104 |
| 141414 | 10510^5105 |
| 151515 | 6×1056\times 10^56×105 |
| 161616 | 7×1057\times 10^57×105 |
| 171717 | 8×1058\times 10^58×105 |
| 181818 | 9×1059\times 10^59×105 |
| 19,2019,2019,20 | 10610^6106 |
C++实现
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int maxn=10000010;
ll n,cnt,ans;
ll size[maxn],head[maxn];
struct node{
int w,to,nt;
}e[maxn*2];
void add(int x,int y,int z){
cnt++;
e[cnt].to=y;
e[cnt].nt=head[x];
e[cnt].w=z;
head[x]=cnt;
}
void dfs(int x,int fa){
size[x]=1;
for(int i=head[x];i;i=e[i].nt)
{
int to=e[i].to;
if(fa==to) continue;
dfs(to,x);
size[x]+=size[to];
ans+=e[i].w*abs(2*size[to]-n);
}
}
int main(){
cin>>n;
for(int i=1;i<n;i++) {
int x,y,z;
scanf("%d%d%d",&x,&y,&z);
add(x,y,z);
add(y,x,z);
}
dfs(1,0);
cout<<ans<<endl;
return 0;
}

后续
接下来我会不断用C++来实现信奥比赛中的算法题、GESP考级编程题实现、白名单赛事考题实现,记录日常的编程生活、比赛心得,感兴趣的请关注,我后续将继续分享相关内容
用C++实现信奥 P2052 NOI2011 道路修建&spm=1001.2101.3001.5002&articleId=147186967&d=1&t=3&u=429d28f0e6ca4b53939208651c185d68)
415

被折叠的 条评论
为什么被折叠?



