题解-CF101D Castle
题面
给一棵 \(n\) 个节点的带权树,求一种遍历方案,从 \(1\) 出发,每条边走两次,走过所有点,第一次经过每个节点的平均时间最小。输出这个平均时间。
数据范围:\(2\le n\le 10^5\)。
题解
可以对于每棵子树单独计算。
虽然子树内走的顺序是不固定的,但是要消耗的总时间是固定的。
设 \(f_u\) 表示 \(u\) 这棵子树内的第一次经过每个节点的 时间和,\(w_{u,v}\) 是 \(u,v\) 两点间的边权,\(sz_u\) 是 \(u\) 的子树大小,\(szt_u\) 是走遍 \(u\) 这棵子树的所需时间。
由于每棵子树遍历一次而且有顺序,记 \(v_i\) 为 \(u\) 第 \(i\) 个遍历的子树。
\]
\(\sum_{i} (f_{v_i}+sz_{v_i}w_{u,v_i})\) 是顺序不同时固定的,\(\sum_{i} (szt_{v_i}+2w_{u,v})\sum_{j>i} sz_{v_j}\) 是会变的,所以这题的难点在于找到它的最小值。
蒟蒻想了好久,这个式子很眼熟,但是怎么化都貌似不能贪心,于是请教了旁边的保队长。
很明显,如果对于 \(i\ge 3\),\(v_i\) 都已经确定,那么 \(p\) 和 \(q\) 分别作为 \(v_1,v_2\) 的贡献是
\]
\]
其实差别就在于 \((szt_p+2w_{u,p})sz_{q}\) 和 \((szt_q+2w_{u,q})sz_{p}\),而且手玩一下可以发现,对于任意两个 \(v\) 顺序都是类似的。
所以把所有 \(v\in son_u\) 丢进一个 vector,然后对于 \(p\),\(q\),按上面的差别排序即可。
代码
#include <bits/stdc++.h>
using namespace std;
//Start
typedef long long ll;
typedef double db;
#define mp(a,b) make_pair((a),(b))
#define x first
#define y second
#define bg begin()
#define ed end()
#define sz(a) int((a).size())
#define pb(a) push_back(a)
#define R(i,a,b) for(int i=(a),i##E=(b);i<i##E;i++)
#define L(i,a,b) for(int i=(b)-1,i##E=(a)-1;i>i##E;i--)
const int iinf=0x3f3f3f3f;
const ll linf=0x3f3f3f3f3f3f3f3f;
//Data
const int N=1e5;
int n;
//Tree
vector<int> e[N],to,we;
void adde(int u,int v,int w){
e[u].pb(sz(to)),to.pb(v),we.pb(w);
e[v].pb(sz(to)),to.pb(u),we.pb(w);
}
int sz[N],szt[N];
ll dfs(int u,int fa){
ll res=0; sz[u]=1,szt[u]=0;
vector<int> cho;
for(int v:e[u])if(to[v]^fa){
res+=dfs(to[v],u);
res+=1ll*we[v]*sz[to[v]];
szt[to[v]]+=we[v]*2;
sz[u]+=sz[to[v]],szt[u]+=szt[to[v]];
cho.pb(to[v]);
}
sort(cho.bg,cho.ed,[&](int p,int q){
return 1ll*szt[p]*sz[q]<1ll*szt[q]*sz[p];
});
int tot=sz[u]-1;
for(int v:cho) tot-=sz[v],res+=1ll*szt[v]*tot;
return res;
}
//Main
int main(){
ios::sync_with_stdio(0);
cin.tie(0),cout.tie(0);
cout.precision(12);
cin>>n;
R(i,1,n){int u,v,w; cin>>u>>v>>w,--u,--v,adde(u,v,w);}
// cout<<dfs(0,-1)<<'\n';
cout<<fixed<<1.*dfs(0,-1)/(n-1)<<'\n';
return 0;
}
祝大家学习愉快!
题解-CF101D Castle的更多相关文章
- CF101D Castle 树形DP、贪心
题目传送门 题意:给出一个有$N$个点的树,你最开始在$1$号点,经过第$i$条边需要花费$w_i$的时间.每条边只能被经过$2$次.求出到达除$1$号点外所有点的最早时间的最小平均值.$N \leq ...
- CF101D Castle
传送门 首先,一定要把所有点遍历一遍,这时答案应该是\(\frac{\sum 某个点第一次被遍历的时间点}{n-1}\quad\),而且每条边只能走两次,所以每次要遍历完某棵子树才能遍历其它子树. 考 ...
- 洛谷 P2945 [USACO09MAR]沙堡Sand Castle 题解
题目传送门 大概思路就是把这两个数组排序.在扫描一次,判断大小,累加ans. #include<bits/stdc++.h> using namespace std; int x,y,z; ...
- 题解 洛谷P1457 【城堡 The Castle】
这道题,看似很烦,无从下手,但其实只要用位运算和联通快就能水过了呀. 首先,输入:似乎大意是把一个数拆成二进数的相加,分别表示\((i,j)\)东南西北是否有墙.\(1\)表示西,\(2\)表示北,\ ...
- 题解 P1457 【城堡 The Castle】
来讨论区大摇大摆地逛了一圈后,我发现竟然大家的代码 都很长 然而代码真的要写那么长吗 首先,来分析问题,1,2,4,8,这些数显然是有特点的,也许你已经想到了没错,它们都是2的次方数. 1是2的0次方 ...
- 洛谷P1457 城堡 The Castle
P1457 城堡 The Castle 137通过 279提交 题目提供者该用户不存在 标签USACO 难度提高+/省选- 提交 讨论 题解 最新讨论 暂时没有讨论 题目描述 我们憨厚的USACO ...
- BZOJ3399: [Usaco2009 Mar]Sand Castle城堡
3399: [Usaco2009 Mar]Sand Castle城堡 Time Limit: 3 Sec Memory Limit: 128 MBSubmit: 22 Solved: 17[Sub ...
- 3399: [Usaco2009 Mar]Sand Castle城堡
3399: [Usaco2009 Mar]Sand Castle城堡 Time Limit: 3 Sec Memory Limit: 128 MBSubmit: 37 Solved: 32[Sub ...
- P1457 城堡 The Castle
轻度中毒 原题 :The Castle 以下为题解部分:明明辣么简单的一道题,硬是搞了1.5h,WTF?以下列出本题的一些要点. 搜索(DFS)嘛,染色嘛,统计大小嘛,很容易想,也很更易处理. 接下来 ...
随机推荐
- 解决SSH显示中文乱码的问题(cent os7)
用SSH连接服务器显示中文乱码,试过修改SSH端,不成功.这次从服务器端下手 1.先查看服务器现有的字符集 [root@dm01 ~]# locale -a 在结果中找到 如果没有支持的字符集就需要安 ...
- REDHAT 7.5beta 新推出的VDO功能
前言 关于VDO VDO的技术来源于收购的Permabit公司,一个专门从事重删技术的公司,所以技术可靠性是没有问题的 VDO是一个内核模块,目的是通过重删减少磁盘的空间占用,以及减少复制带宽,VDO ...
- 常用linux源列表
本篇记录一些常用的源文件,后面需要用到的时候,直接进行复制粘贴即可 centos 相关 base源 [base] name=CentOS-$releasever - Base - mirrors.al ...
- springboot linux打包后访问不到resources 下面的模板文件
在本地是可以直接获取模板文件并下载,但是服务器上就不行 本地代码: @Overridepublic void downArchRelayTemplate(HttpServletRequest requ ...
- Python_网络编程_socket()
什么是 Socket? Socket又称"套接字",应用程序通常通过"套接字"向网络发出请求或者应答网络请求,使主机间或者一台计算机上的进程间可以通讯. 详细资 ...
- No matching distribution found for Tensorflow
No matching distribution found for Tensorflow 原因:python 3.7.3 版本过高 解决:安装3.6 64位
- tp5 生成随机数
控制器调用 public function GetRanStr(){ if (request()->isPost()) { //生成6位数随机数 return GetRandStr(6); } ...
- 深度分析:面试腾讯,阿里面试官都喜欢问的String源码,看完你学会了吗?
前言 最近花了两天时间,整理了一下String的源码.这个整理并不全面但是也涵盖了大部分Spring源码中的方法.后续如果有时间还会将剩余的未整理的方法更新到这篇文章中.方便以后的复习和面试使用.如果 ...
- Hadoop优化之数据压缩
bBHadoop数据压缩 概述 运行hadoop程序时,I/O操作.网络数据传输.shuffle和merge要花大量的时间,尤其是数据规模很大和工作负载密集的情况下,这个时候,使用数据压缩可以提高效率 ...
- yii2.0验证码的两种实现方式
第一种方式:采用model 1. 模型:Code.php <?phpnamespace app\models; use yii\base\Model;class Code extends Mod ...