Portal --> cf113D

Solution

  额题意的话大概就是给一个无向图然后两个人给两个出发点,每个点每分钟有\(p[i]\)的概率停留,问这两个人在每个点相遇的概率是多少

  如果说我们知道最后在哪里相遇,处理起来会比较方便。注意到\(n\)比较小,所以考虑枚举最后相遇的房间,然后可以看成求两个人同时从最后相遇的房间出发,走到\(X\)和\(Y\)的概率,这样初始状态什么的比较好表示,就会好求很多了(跟。。hnoi2013游走有点像?)

  考虑\(dp\) ,假设我们现在枚举到终点是\(t\),\(f[i][j]\)表示第一个人在\(i\)这个点,第二个人在\(j\)这个点的概率是多少

  那么有初始状态:

    1.\(i==j==t\)的情况,\(f[i][j]=1\)

    2.\(i==j!=t\)的情况,\(f[i][j]=0\)

  考虑从第\(i\)个房间走向一个相邻房间的概率\(k[i]\),记第\(i\)个点的度数为\(du[i]\),那么有

\[k[i]=\frac{1-p[i]}{du[i]}
\]

  (有\(1-p[i]\)的概率离开这个房间,并且走向每个相邻房间的概率是一样的)

  所以我们可以得到转移:

\[\begin{aligned}
f[i][j]&=p[i]*p[j]*f[i][j]&(都停留)\\
&+k[i]*p[j]*\sum f[u][j]&(第一个人走一步)\\
&+k[j]*p[i]*\sum f[i][v]&(第二个人走一步)\\
&+k[i]*k[j]*\sum f[u][v]&(两个人都走一步)
\end{aligned}
\]

  其中\(u\)满足\(i\)和\(u\)在原图中有一条边直接相连,\(v\)满足\(v\)和\(j\)在原图中有一条边直接相连

  然后移下项,对于每一对\((i,j)\)我们都可以得到一条长得像这样的式子:

\[\sum a_{i,j}*f[i][j]=c
\]

  将\(f[i][j]\)看成未知数,就可以直接用高斯消元来做了

  注意,移项的时候,因为在初始化中\(f[i][i]\)的值已经定下来了,所以应该当成常数来看

  

  代码大概长这个样子

#include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath>
#define db double
using namespace std;
const int N=25;
int mp[N][N],du[N];
db p[N],a[N*N][N*N],k[N],f[N],num[N][N];
int n,m,X,Y,mx;
db ans[N];
void fillmatrix(int t);
db gauss(int n);
void solve(int t);
void Fill(int x,int y);
int Id(int x,int y){return num[x][y];} int main(){
#ifndef ONLINE_JUDGE
freopen("a.in","r",stdin);
#endif
int x,y;
scanf("%d%d%d%d",&n,&m,&X,&Y);
for (int i=1;i<=m;++i){
scanf("%d%d",&x,&y);
mp[x][y]=mp[y][x]=1;
++du[x]; ++du[y];
}
if (X==Y){
for (int i=1;i<=n;++i)
if (i==X) printf("%.10lf\n",1.0);
else printf("%.10lf\n",0.0);
return 0;
}
for (int i=1;i<=n;++i) scanf("%lf",p+i);
for (int i=1;i<=n;++i) k[i]=(1.0-p[i])/(1.0*du[i]);
mx=0;
for (int i=1;i<=n;++i)
for (int j=1;j<=n;++j)
if (i!=j) num[i][j]=++mx;
for (int i=1;i<=n;++i)
solve(i);
for (int i=1;i<=n;++i)
printf("%.10lf ",ans[i]);
printf("\n");
} void solve(int t){
fillmatrix(t);
ans[t]=gauss(mx);
} void fillmatrix(int t){
int id;
memset(a,0,sizeof(a));
memset(f,0,sizeof(f));
f[t]=1;
for (int i=1;i<=n;++i){
for (int j=1;j<=n;++j){
if (i!=j) Fill(i,j);
}
}
} void Fill(int x,int y){
int id=Id(x,y);
a[id][id]=p[x]*p[y]-1.0;
for (int i=1;i<=n;++i){
if (mp[i][x]){
if (i!=y)
a[id][Id(i,y)]+=k[x]*p[y];
else
a[id][mx+1]-=k[x]*p[y]*f[y];
}
if (mp[i][y]){
if (i!=x)
a[id][Id(x,i)]+=k[y]*p[x];
else
a[id][mx+1]-=k[y]*p[x]*f[x];
}
for (int j=1;j<=n;++j){
if (mp[i][x]&&mp[j][y]){
if (i!=j)
a[id][Id(i,j)]+=k[x]*k[y];
else
a[id][mx+1]-=k[x]*k[y]*f[j];
}
}
}
} db gauss(int n){
int id;
db tmp;
for (int i=1;i<=n;++i){
id=i;
for (int j=i+1;j<=n;++j)
if (fabs(a[j][i])>fabs(a[id][i])) id=j;
if (id!=i)
for (int j=1;j<=n+1;++j) swap(a[i][j],a[id][j]);
for (int j=i+1;j<=n;++j){
tmp=a[j][i]/a[i][i];
for (int k=i;k<=n+1;++k)
a[j][k]-=tmp*a[i][k];
}
}
for (int i=n;i>=1;--i){
for (int j=n;j>i;--j)
a[i][n+1]-=a[i][j]*a[j][n+1];
a[i][n+1]/=a[i][i];
}
return a[Id(X,Y)][mx+1];
}

【CF113D】Museum的更多相关文章

  1. 【254】◀▶IEW-Unit19

    Unit 19 Technology Communication I.名词性从句在雅思写作中的运用 英语中哪些位置可以放名词? 1)主语 2)宾语 3)表语 4)同位语 名词的位置放一个句子=名词性从 ...

  2. Python高手之路【六】python基础之字符串格式化

    Python的字符串格式化有两种方式: 百分号方式.format方式 百分号的方式相对来说比较老,而format方式则是比较先进的方式,企图替换古老的方式,目前两者并存.[PEP-3101] This ...

  3. 【原】谈谈对Objective-C中代理模式的误解

    [原]谈谈对Objective-C中代理模式的误解 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 这篇文章主要是对代理模式和委托模式进行了对比,个人认为Objective ...

  4. 【原】FMDB源码阅读(三)

    [原]FMDB源码阅读(三) 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 FMDB比较优秀的地方就在于对多线程的处理.所以这一篇主要是研究FMDB的多线程处理的实现.而 ...

  5. 【原】Android热更新开源项目Tinker源码解析系列之一:Dex热更新

    [原]Android热更新开源项目Tinker源码解析系列之一:Dex热更新 Tinker是微信的第一个开源项目,主要用于安卓应用bug的热修复和功能的迭代. Tinker github地址:http ...

  6. 【调侃】IOC前世今生

    前些天,参与了公司内部小组的一次技术交流,主要是针对<IOC与AOP>,本着学而时习之的态度及积极分享的精神,我就结合一个小故事来初浅地剖析一下我眼中的“IOC前世今生”,以方便初学者能更 ...

  7. Python高手之路【三】python基础之函数

    基本数据类型补充: set 是一个无序且不重复的元素集合 class set(object): """ set() -> new empty set object ...

  8. Python高手之路【一】初识python

    Python简介 1:Python的创始人 Python (英国发音:/ˈpaɪθən/ 美国发音:/ˈpaɪθɑːn/), 是一种解释型.面向对象.动态数据类型的高级程序设计语言,由荷兰人Guido ...

  9. 【开源】简单4步搞定QQ登录,无需什么代码功底【无语言界限】

    说17号发超简单的教程就17号,qq核审通过后就封装了这个,现在放出来~~ 这个是我封装的一个开源项目:https://github.com/dunitian/LoTQQLogin ————————— ...

随机推荐

  1. python爬虫之requests库

    在python爬虫中,要想获取url的原网页,就要用到众所周知的强大好用的requests库,在2018年python文档年度总结中,requests库使用率排行第一,接下来就开始简单的使用reque ...

  2. Python range() 函数用法

    函数语法 range(start, stop[, step]) 参数说明: start: 计数从 start 开始.默认是从 0 开始.例如range(5)等价于range(0, 5); stop: ...

  3. 教你thinkphp5怎么配置二级域名

    有些项目要将移动端和PC端分离开来,比如访问xxx.com,展示的是PC端的页面.而访问m.xxx.com,展示的是移动端的页面.thinkphp源码需要多多学习,这里记录一下知识点,顺便分享给需要的 ...

  4. Open vSwitch for CentOS

    原文发表于cu:2016-06-02 本文属于重发,ovs当前的安装方式可能略有不同. 参考文档: 官方文档: http://openvswitch.org/support/dist-docs-2.5 ...

  5. presto——java.sql.SQLException: Error executing query与javax.net.ssl.SSLException: Unrecognized SSL message, plaintext connection?异常问题

    使用presto的时候以mysql为presto的数据源 安装的presto是0.95版本:使用的presto-jdbc是0.202的,这里使用jdbc去访问时候,connection可以链接成功,但 ...

  6. BFC的表象认识

    首先字面翻译,这三个字母分别代表什么,box,formatting, context,它决定了元素如何对其内容进行定位,以及与其他元素的关系和相互作用. 形象点就是说一种规范,规范什么呢?规范盒子内部 ...

  7. oracle数据库 expdp/impdp 和 exp/imp

    --EXPDP导出,需要系统用户权限,一般不使用--sqlplus--1.创建dmp导出逻辑目录 create directory 目录名 as '目录路径' create directory exp ...

  8. 电梯V2.0

    电梯V2.0 GitHub仓库地址 Problem 一栋10层的大楼(楼层编号1-10),设3台无限载重的电梯,初始时电梯停在1层.其中:1号电梯只能停留在奇数层,2号电梯可以各层都停留,3号电梯只停 ...

  9. 周总结<8>

    周次 学习时间 新编代码行数 博客量 学到知识点 15 15 100 1 Html页面设计:虚拟机:(C语言)排序 Html案例: <!DOCTYPE html PUBLIC "-// ...

  10. Alpha 冲刺8

    队名:日不落战队 安琪(队长) 今天完成的任务 登录的数据post. okhttp学习第二弹. 明天的计划 okhttp学习第三弹. 个人信息界面数据get. 还剩下的任务 个人信息数据get. 遇到 ...