社区讨论
求助!!站外题
学术版参与者 2已保存回复 2
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 2 条
- 当前快照
- 1 份
- 快照标识符
- @lo28ro4d
- 此快照首次捕获于
- 2023/10/23 09:51 2 年前
- 此快照最后确认于
- 2023/11/03 10:04 2 年前
给定一棵有向树T,树T 中每个顶点u都有一个权w(u);树的每条边(u,v)也都有一个非负边长d(u,v)。有向树T的每个顶点u 可以看作客户,其服务需求量为w(u)。每条边(u,v)的边长d(u,v) 可以看作运输费用。如果在顶点u 处未设置服务机构,则将顶点u 处的服务需求沿有向树的边(u,v)转移到顶点v 处服务机构需付出的服务转移费用为w(u)*d(u,v)。树根处已设置了服务机构,现在要在树T中增设k处服务机构,使得整棵树T 的服务转移费用最小。
编程任务:对于给定的有向树T,编程计算在树T中增设k处服务机构的最小服务转移费用。
输入
第1行有2个正整数n和k。n表示有向树T 的边数;
k是要增设的服务机构数。有向树T 的顶点编号为0,1,…,n。根结点编号为0。
接下来的n行中,每行有表示有向树T的一条有向边的3个整数。第i+1行的3 个整数wi,vi,di分别表示编号为i 的顶点的权为wi,相应的有向边为(i, vi),其边长为di。
输出
最小服务转移费。
样例输入 Copy
4 2
1 0 1
1 1 10
10 2 5
1 2 3
样例输出 Copy
4
回复
共 2 条回复,欢迎继续交流。
正在加载回复...