2017 Multi-University Training Contest - Team 3 RXD and dividing(树)
2024-09-04 10:32:31
题解:
其实贪心地算就可以了
一个最优的分配就是每条边权贡献的值为min(k, sz[x]),sz[x]是指子树的大小
然后最后加起来就是答案。
#include <iostream>
#include <cstring>
#include <cstdio>
#include <vector>
#include <set>
#define fi first
#define se second
using namespace std;
const int maxn = 1e6 + ;
typedef pair<long long, int> PLI;
typedef pair<int, long long> PIL;
vector<PIL> G[maxn];int sz[maxn], k;
long long ans = ;
void dfs(int x, int fa){
sz[x] = ;
for(auto e : G[x]){
if(e.fi == fa) continue;
dfs(e.fi, x);
sz[x] += sz[e.fi];
ans += min(k, sz[e.fi])*e.se;
}
} int main()
{
int x, y, v, n;
while(cin>>n>>k){
ans = ;
for(int i = ; i <= n; i++) G[i].clear();
for(int i = ; i < n; i++){
scanf("%d %d %d", &x, &y, &v);
G[x].push_back({y, v});
G[y].push_back({x, v});
}
dfs(, );
cout<<ans<<endl;
}
}
最新文章
- 如何让C#像JavaScript一样编程
- ASP.NET 5与MVC 6中的新特性
- windows添加虚拟网卡
- 【C#】委托
- NimBus一个好的开发框架
- google模拟各种Android手机浏览器方法
- Swift - 告警提示框(UIAlertController)的用法
- C#总结(二)事件Event 介绍总结
- .NET链接Oracle 参数绑定问题
- mysql的复杂查询,连接数据库
- 2018上C语言程序设计(高级)作业- 第1次作业
- WPF TextBlock 判断 isTextTrimmed 文本是否超出
- phpstorm本地怎么上传到服务器
- How do I copy files that need root access with scp
- Android从启动到程序运行整个过程的整理
- 【bfs】迷宫问题
- js 图片压缩上传(纯js的质量压缩,非长宽压缩)
- 语音笔记:MFCC
- __getattr__和__setattt__使用
- (实用)pip源