博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
CF235D Graph Game
阅读量:6579 次
发布时间:2019-06-24

本文共 1432 字,大约阅读时间需要 4 分钟。

 

好题

树?

考虑每个点被计算多少次

但是和当前分治中心有关系的(相当于我们把这次访问,归到这次的中心上去)

所以,f(a,b),对于a作为中心时候,和b相连的概率

也就是两者必然分离,最后一次连在一起的时候,是否能够恰好选择a

贡献:1/(dis(x,y))

基环树?

考虑:

a,b最后一起之前断的边,在所有可能情况中,关心(a-y-b)先断的是哪一个,概率1/(x+y),(a-z-b) 先断哪一个1/(x+z)

但是还有一种合法情况:直接断x,别的都不动。两者中会算重,减去1/(x+y+z)

所以,1/(x+y)+1/(x+z)-1/(x+y+z)

(条件概率也可以推式子证明,通分后得到同样结果)

 

#include
#define reg register int#define il inline#define fi first#define se second#define mk(a,b) make_pair(a,b)#define numb (ch^'0')#define ld double using namespace std;typedef long long ll;template
il void rd(T &x){ char ch;x=0;bool fl=false; while(!isdigit(ch=getchar()))(ch=='-')&&(fl=true); for(x=numb;isdigit(ch=getchar());x=x*10+numb); (fl==true)&&(x=-x);}template
il void output(T x){
if(x/10)output(x/10);putchar(x%10+'0');}template
il void ot(T x){
if(x<0) putchar('-'),x=-x;output(x);putchar(' ');}template
il void prt(T a[],int st,int nd){
for(reg i=st;i<=nd;++i) ot(a[i]);putchar('\n');}namespace Miracle{const int N=3003;int n;struct node{ int nxt,to;}e[2*N];int hd[N],cnt;void add(int x,int y){ e[++cnt].nxt=hd[x]; e[cnt].to=y; hd[x]=cnt;}int sta[N],top;bool vis[N];bool fl;int on[N],mem[N],num;void fin(int x,int fa){ sta[++top]=x;vis[x]=1;// cout<<" xx "<
<<" fa "<
<
View Code

 

转载于:https://www.cnblogs.com/Miracevin/p/10624174.html

你可能感兴趣的文章
(转)那些年,被自己的技术者思维虐过的项目经理们
查看>>
java 实现redis缓存
查看>>
那些终将掩埋自己的坑
查看>>
转-深入理解VMware虚拟网络
查看>>
百家姓日文读音<转载>
查看>>
eclipse 无法解析导入 javax.servlet 的解决方法
查看>>
close方法
查看>>
排行榜的写法
查看>>
SOAPdenove 安装心得
查看>>
jQuery源码分析
查看>>
org.xml.sax.SAXParseException: Failed to read schema document 的原因分析与解决方法
查看>>
window上创建python3虚拟环境
查看>>
iOS-CALayer实现简单进度条
查看>>
代码规范-箭头函数的四种写法
查看>>
Ubuntu 系统学习
查看>>
2014.4.24—一切都是为了更好地生活
查看>>
wepy笔记之原生小程序、vue、wepy之间的差异记录
查看>>
vue官方webpack模版多个打包环境搭建
查看>>
Tomcat服务器 和 HTTP协议
查看>>
复选框的全选和取消
查看>>