Codeforces Round #411 (Div. 1) D. Expected diameter of a tree
题目大意:给出一个森林,每次询问给出u,v,问从u所在连通块中随机选出一个点与v所在连通块中随机选出一个点相连,连出的树的直径期望(不是树输出-1)。(n,q<=10^5)
解法:预处理出各连通块的直径和各点到连通块内一点的最远距离d[x](树形dp+换根),询问若在同一块内输出-1,否则若随机选出两点x,y,直径为max(d[x]+d[y]+1,x所在块直径,y所在块直径),我们把同一连通块内的d排序,枚举小的连通块中的d,到大的连通块中二分d[x]+d[y]+1<=max(x所在块直径,y所在块直径)(或者记下大的块中每种权值出现次数,从max直径开始d[x]递增d[y]递减,复杂度少一个log并仍然只与小的块的大小相关),记忆下相同询问,这样我们枚举小的次数最大只有$O(n^{1.5})$(每次我们复杂度只跟小的有关,那么最劣情况只有每次两个块大小相等,假设所有联通块大小均为k,我们的复杂度是$O(k*min(q,(\frac{n}{k})^2))$,容易证明复杂度最大是$O(n^{1.5})$)。
#include<cstdio>
#include<algorithm>
#include<vector>
#include<map>
using namespace std;
inline int read()
{
int x;char c;
while((c=getchar())<''||c>'');
for(x=c-'';(c=getchar())>=''&&c<='';)x=(x<<)+(x<<)+c-'';
return x;
}
#define MN 100000
#define p(x,y) make_pair(x,y)
struct edge{int nx,t;}e[MN*+];
int f[MN+],h[MN+],en,d[MN+],d2[MN+],mx[MN+];
vector<double> v[MN+];
map<pair<int,int>,double> mp;
int gf(int k){return f[k]?f[k]=gf(f[k]):k;}
inline void ins(int x,int y)
{
e[++en]=(edge){h[x],y};h[x]=en;
e[++en]=(edge){h[y],x};h[y]=en;
}
void upd(int x,int y)
{
if(y>d[x])d2[x]=d[x],d[x]=y;
else if(y>d2[x])d2[x]=y;
}
void dp(int x,int fa)
{
for(int i=h[x];i;i=e[i].nx)if(e[i].t!=fa)
dp(e[i].t,x),upd(x,d[e[i].t]+);
mx[gf(x)]=max(mx[gf(x)],d[x]+d2[x]);
}
void dfs(int x,int fa)
{
v[gf(x)].push_back(d[x]);
for(int i=h[x];i;i=e[i].nx)if(e[i].t!=fa)
upd(e[i].t,d[e[i].t]+==d[x]?d2[x]+:d[x]+),dfs(e[i].t,x);
}
int main()
{
int n,m,q,x,y,i,j,l,r,mid,res;double ans;
n=read();m=read();q=read();
while(m--)ins(x=read(),y=read()),f[gf(x)]=gf(y);
for(i=;i<=n;++i)if(gf(i)==i)
{
dp(i,i);dfs(i,i);v[i].push_back();
sort(v[i].begin(),v[i].end());
for(j=;j<v[i].size();++j)v[i][j]+=v[i][j-];
}
while(q--)
{
if((x=gf(read()))==(y=gf(read()))){puts("-1");continue;}
if(x>y)swap(x,y);
if(mp[p(x,y)]){printf("%.10lf\n",mp[p(x,y)]);continue;}
if(v[x].size()>v[y].size())swap(x,y);
for(i=,ans=;i<v[x].size();++i)
{
for(l=,r=v[y].size()-,res=;l<=r;)
{
mid=l+r>>;
if(v[x][i]-v[x][i-]+v[y][mid]-v[y][mid-]+<=max(mx[x],mx[y]))
res=mid,l=mid+;
else r=mid-;
}
ans+=(double)res*max(mx[x],mx[y])+
(v[y].size()--res)*(v[x][i]-v[x][i-]+)+v[y][v[y].size()-]-v[y][res];
}
if(x>y)swap(x,y);
printf("%.10lf\n",mp[p(x,y)]=ans/(v[x].size()-)/(v[y].size()-));
}
}
Codeforces Round #411 (Div. 1) D. Expected diameter of a tree的更多相关文章
- Codeforces Round #411 (Div. 2)
来自FallDream的博客,未经允许,请勿转载,谢谢. 由于人傻又菜 所以这次又滚去div2了 一堆结论题真的可怕 看见E题不是很有思路 然后就去大力搞F题 T了最后一个点 真的绝望 但 ...
- Codeforces Round #411 (Div. 2) A-F
比赛时候切了A-E,fst了A Standings第一页只有三个人挂了A题,而我就是其中之一,真™开心啊蛤蛤蛤 A. Fake NP time limit per test 1 second memo ...
- Codeforces Round 411 Div.2 题解
A Fake NP standard input/output s, MB Submit Add to favourites x3673 B -palindrome standard input/ou ...
- Codeforces Round #411 (Div. 2)(A,B,C,D 四水题)
A. Fake NP time limit per test:1 second memory limit per test:256 megabytes input:standard input out ...
- Codeforces Round #411 div 2 D. Minimum number of steps
D. Minimum number of steps time limit per test 1 second memory limit per test 256 megabytes input st ...
- Codeforces Round #411 (Div. 2) 【ABCDE】
A. Fake NP 题意:给你l,r,让你输出[l,r]里面除1以外的,出现因子数量最多的那个数. 题解:如果l==r输出l,否则都输出2 #include<bits/stdc++.h> ...
- Codeforces Round #411 (Div. 2) C. Find Amir
C. Find Amir time limit per test 1 second memory limit per test 256 megabytes A few years ago ...
- 【DFS】【贪心】Codeforces Round #411 (Div. 1) C. Ice cream coloring
对那个树进行dfs,在动态维护那个当前的冰激凌集合的时候,显然某种冰激凌仅会进出集合各一次(因为在树上形成连通块). 于是显然可以对当前的冰激凌集合贪心染色.暴力去维护即可.具体实现看代码.map不必 ...
- 【推导】Codeforces Round #411 (Div. 1) B. Minimum number of steps
最后肯定是bbbb...aaaa...这样. 你每进行一系列替换操作,相当于把一个a移动到右侧. 会增加一些b的数量……然后你统计一下就行.式子很简单. 喵喵喵,我分段统计的,用了等比数列……感觉智障 ...
随机推荐
- Beta项目复审
Beta项目复审 复审人:张宇光 所属团队:MyGod 团队成员:程环宇.王田路.张芷祎.张宇光.王婷婷 团队排名: SW_HW4-team团队 hyw-team团队 Java-Team团队 C++团 ...
- python实现线性回归
参考:<机器学习实战>- Machine Learning in Action 一. 必备的包 一般而言,这几个包是比较常见的: • matplotlib,用于绘图 • numpy,数组处 ...
- "一不小心就火了"团队采访
团队采访 一. 采访团队 团队:一不小心就火了 采访形式:线上问答 二.采访内容 你们是怎么合理地具体分配组员里的工作的?有些团队会出现个别组员代码任务很重,个别组员无所事事的情况,你们有什么有效的方 ...
- EasyUI 中easyui-textbox和easyui-searchbox文本框的点击事件。
html: <input id="txtsearch" class="easyui-textbox" data-options="buttonT ...
- JAVA_SE基础——69.Date类
package cn.itcast.other; import java.text.ParseException; import java.text.SimpleDateFormat; import ...
- app测试中遇到问题总结
工作总结: 1 这两天由于工作,需要进行抓包,使用了Charles,fidder,发现一个坑点: charles没有抓到返回值的时候,默认是不在列表显示请求信息的,能不能设置,我就不知道了,但是可以在 ...
- Jenkins+maven+git配置
1) 安装maven 如下图我已装好maven(这是我很早以前装的,安装教程大家可以百度一下,很容易安装的) 2) 安装git客户端 如下图所示,我也安装好了git客户 ...
- String、StringBuffer、StringBulider之间的联系和区别
首先,我们大概总体的解释一下这三者的区别和联系 String的值是不可变的,这就导致每次对String的操作都会生成新的String对象,不仅效率低下,而且大量浪费有限的内存空间. StringBuf ...
- Struts(二十五):自定义验证器
编程验证 Struts2提供了一个Validateable接口,可以使用Action类实现这个接口以提供编程验证: ActionSupport类已经实现了Validateable接口. public ...
- format的应用
>>> "{a} love {b}.{c}".format(a="I", b="Fish", c="com&qu ...