用$F(i,j)$表示A在i,B在j的概率。

然后很容易列出转移方程。

然后可以高斯消元了!

被一个问题困扰了很久,为什么起始点的概率要加上1。

(因为其他博客上都是直接写成-1,雾)

考虑初始状态是由什么转移过来的,发现可以由其他点走过来,也可以由初始定义转移。

而初始的定义就决定了它有一个1的概率。

加上之后就可以高斯消元了

#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std;
#define F(i,j,k) for (int i=j;i<=k;++i)
#define D(i,j,k) for (int i=j;i>=k;--i)
double a[405][405],p[21];
int id[21][21],n,m,x,y,du[21],tot,st;
int h[405],to[405],ne[405],en=0; void add(int a,int b)
{
to[en]=b;ne[en]=h[a];h[a]=en++;
} void solve(int x,int y)
{
int num=id[x][y];
a[num][num]=1.0;
for (int i=h[x];i>=0;i=ne[i])
for (int j=h[y];j>=0;j=ne[j])
{
int tx=to[i],ty=to[j]; if (tx==ty) continue;
int tnum=id[tx][ty];
if (tx==x&&ty==y) a[num][tnum]-=p[tx]*p[ty];
else if (tx==x) a[num][tnum]-=p[tx]*(1-p[ty])/(du[ty]*1.0);
else if (ty==y) a[num][tnum]-=p[ty]*(1-p[tx])/(du[tx]*1.0);
else a[num][tnum]-=(1-p[tx])*(1-p[ty])/(du[tx]*1.0)/(du[ty]*1.0);
}
} void gauss()
{
F(i,1,tot)
{
int tmp=i;
while (!a[tmp][i]&&tmp<=tot) tmp++;
if (tmp>tot) continue;//自由元
F(j,i,tot+1) swap(a[i][j],a[tmp][j]);
F(j,1,tot) if (j!=i)
{
double t=a[j][i]/a[i][i];
F(k,1,tot+1)
a[j][k]-=t*a[i][k];
}
}
} int main()
{
memset(h,-1,sizeof h);
scanf("%d%d%d%d",&n,&m,&x,&y);
F(i,1,m)
{
int a,b;
scanf("%d%d",&a,&b);
add(a,b);add(b,a);
du[a]++;du[b]++;
}
F(i,1,n) add(i,i);
F(i,1,n) F(j,1,n) id[i][j]=++tot;
a[id[x][y]][tot+1]=1;
F(i,1,n) scanf("%lf",&p[i]);
F(i,1,n) F(j,1,n) solve(i,j);
gauss();
F(i,1,n)
{
int t=id[i][i];
printf("%.6f ",a[t][tot+1]/a[t][t]);
}
printf("\n");
}

  我怎么还是不会写高斯消元?(⊙_⊙?)

方法二:

考虑初始向量S,转移矩阵A

那么答案就是$ans=SI+SA+SA^2...$

所以$ans=S(I-A)^{-1}$

然后就有$ans[I-A]^{T}=S$

高斯消元即可,或者求逆之后矩阵乘法

#include <map>
#include <ctime>
#include <cmath>
#include <queue>
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std;
#define F(i,j,k) for (int i=j;i<=k;++i)
#define D(i,j,k) for (int i=j;i>=k;--i)
#define maxn 405
double f[402][402],p[402],d[402][402];
double ans[402],S[402];
int ed,n,m,sa,sb,cnt;
int id[21][21],du[maxn],h[maxn],to[maxn],ne[maxn],en=0;
void add(int a,int b)
{to[en]=b;ne[en]=h[a];h[a]=en++;} void Build()
{
ed=cnt;
F(i,1,n) F(j,1,n)
if (i!=j) F(k,1,n) F(l,1,n)
f[id[i][j]][id[k][l]]-=d[i][k]*d[j][l];
F(i,1,ed) F(j,1,i-1) swap(f[i][j],f[j][i]);
F(i,1,ed) f[i][i]+=1;
f[id[sa][sb]][ed+1]=1;
} void Gauss()
{
F(i,1,ed)
{
int tmp=i;
F(j,i+1,ed) if (f[j][i]>f[tmp][i]) tmp=j;
if (tmp!=i) F(j,i,ed+1) swap(f[tmp][j],f[i][j]);
F(j,i+1,ed)
{
double t=f[j][i]/f[i][i];
F(k,i,ed+1) f[j][k]-=t*f[i][k];
}
}
D(i,ed,1)
{
F(j,i+1,ed) f[i][ed+1]-=f[i][j]*ans[j],f[i][j]=0;
ans[i]=f[i][ed+1]/f[i][i];
}
} int main()
{
memset(h,-1,sizeof h);
scanf("%d%d%d%d",&n,&m,&sa,&sb);
F(i,1,m)
{
int a,b;
scanf("%d%d",&a,&b);
add(a,b);add(b,a);
du[a]++;du[b]++;
}
F(i,1,n) scanf("%lf",&p[i]);
F(i,1,n)
{
d[i][i]=p[i];
for (int j=h[i];j>=0;j=ne[j])
d[i][to[j]]+=(1-p[i])/du[i];
}
F(i,1,n) F(j,1,n) id[i][j]=++cnt;
Build();
Gauss();
F(i,1,n) printf("%.6f ",ans[id[i][i]]);
}

  

BZOJ 3270 博物馆 ——概率DP 高斯消元的更多相关文章

  1. BZOJ 3270: 博物馆 [概率DP 高斯消元]

    http://www.lydsy.com/JudgeOnline/problem.php?id=3270 题意:一张无向图,一开始两人分别在$x$和$y$,每一分钟在点$i$不走的概率为$p[i]$, ...

  2. bzoj 3270: 博物馆【dp+高斯消元】

    好像是高斯消元解互相推(?)的dp的例子 首先考虑dp,设f[i][j]为一人在i一人在j的概率,点i答案显然就是f[i][i]: 然后根据题意,得到转移是 \[ f[i][j]=f[i][j]*p_ ...

  3. 【BZOJ3270】博物馆 概率DP 高斯消元

    链接: #include <stdio.h> int main() { puts("转载请注明出处[辗转山河弋流歌 by 空灰冰魂]谢谢"); puts("网 ...

  4. BZOJ3270 博物館 概率DP 高斯消元

    BZOJ3270 博物館 概率DP 高斯消元 @(XSY)[概率DP, 高斯消元] Description 有一天Petya和他的朋友Vasya在进行他们众多旅行中的一次旅行,他们决定去参观一座城堡博 ...

  5. BZOJ_1778_[Usaco2010 Hol]Dotp 驱逐猪猡_概率DP+高斯消元

    BZOJ_1778_[Usaco2010 Hol]Dotp 驱逐猪猡_概率DP+高斯消元 题意: 奶牛们建立了一个随机化的臭气炸弹来驱逐猪猡.猪猡的文明包含1到N (2 <= N <= 3 ...

  6. LightOJ - 1151概率dp+高斯消元

    概率dp+高斯消元 https://vjudge.net/problem/LightOJ-1151 题意:刚开始在1,要走到100,每次走的距离1-6,超过100重来,有一些点可能有传送点,可以传送到 ...

  7. 【bzoj1778】[Usaco2010 Hol]Dotp 驱逐猪猡 矩阵乘法+概率dp+高斯消元

    题目描述 奶牛们建立了一个随机化的臭气炸弹来驱逐猪猡.猪猡的文明包含1到N (2 <= N <= 300)一共N个猪城.这些城市由M (1 <= M <= 44,850)条由两 ...

  8. 【BZOJ3640】JC的小苹果 概率DP+高斯消元

    [BZOJ3640]JC的小苹果 Description 让我们继续JC和DZY的故事. “你是我的小丫小苹果,怎么爱你都不嫌多!” “点亮我生命的火,火火火火火!” 话说JC历经艰辛来到了城市B,但 ...

  9. 【概率dp 高斯消元】bzoj3270: 博物馆

    一类成环概率dp的操作模式 Description 有一天Petya和他的朋友Vasya在进行他们众多旅行中的一次旅行,他们决定去参观一座城堡博物馆.这座博物馆有着特别的样式.它包含由m条走廊连接的n ...

随机推荐

  1. SVN客户端--TortoiseSVN使用说明

    TortoiseSVN是windows下其中一个非常优秀的SVN客户端工具.通过使用它,我们可以可视化的管理我们的版本库.不过由于它只是一个客户端,所以它不能对版本库进行权限管理. TortoiseS ...

  2. Django之CSRF问题

    1.csrf全称:cross site request forgery(跨站请求伪造),举例来讲,一个安全的网站A,一个恶意网站B,当你在A网站进行了登录后,这时候浏览器会保存你的cookie和ses ...

  3. 洛谷 P2483 [SDOI2010]魔法猪学院

    题目描述 iPig在假期来到了传说中的魔法猪学院,开始为期两个月的魔法猪训练.经过了一周理论知识和一周基本魔法的学习之后,iPig对猪世界的世界本原有了很多的了解:众所周知,世界是由元素构成的:元素与 ...

  4. Python相关机器学习

    Python机器学习库 Python的机器学习库汇总与梳理 机器学习之开源库大总结

  5. uva12264 Risk

    最小值最大,就二分判断. map[i] = '0'+map[i];这样更方便 每个点拆成i,i’,  S连i,cap为a[i],i’连T,cap为1(保证至少剩一个)或mid. i,i’ ,a[i] ...

  6. oracle数据比对工具

    上半年的工作重心主要是机房搬迁,免不了要经常的数据比对,保证主备库数据一致,为了节约工作时间,提高工作效率,开发了这个数据比对小工具.用起来还可以.有需要的QQ私聊(1603039990),方便大家, ...

  7. Robotium实践之路源码创建测试项目

    1.JDK安装及环境配置 2.Eclipse安装 3.ADT插件安装 4.模拟器安装 5.准备源码 6.引进源码置项目中 .文件 .导入 .选择现有项目置工作空间中 .浏览 .选择项目,选择模拟器版本 ...

  8. lucene4.10.2实例(增删改查)

    最新jar和src免费下载:http://download.csdn.net/detail/u011518709/8248403 lucene 包的组成结构:对于外部应用来说索引模块(index)和检 ...

  9. LeetCode 岛屿的最大面积

    给定一个包含了一些 0 和 1的非空二维数组 grid , 一个 岛屿 是由四个方向 (水平或垂直) 的 1 (代表土地) 构成的组合.你可以假设二维矩阵的四个边缘都被水包围着. 找到给定的二维数组中 ...

  10. (29)zabbix执行远程命令

    概述 监控,有的人只把他当做报警使用,出现问题之后打开跑回家打开电脑,巴拉巴拉的处理掉,大多数时候都是一些小问题,为何不让zabbix帮你把这些事情处理掉呢?和朋友具体,收到xx硬盘空间慢了.xx服务 ...