Sol

期望DP+高斯消元.

根据本题题意列出期望方程
\[E(i,j)=(1-p_i)(1-p_j)E(u,v)+(1-p_i)p_jE(u,j)+p_i(1-p_j)E(i,v)+p_ip_jE(i,j),u\in Edge(i,u),v\in Edge(j,v)\]
移项得
\[(1-p_i)(1-p_j)E(u,v)+(1-p_i)p_jE(u,j)+p_i(1-p_j)E(i,v)+(p_ip_j-1)E(i,j)=0,u\in Edge(i,u),v\in Edge(j,v)\]

然后就可以高斯消元了,特殊的因为至少走一步所以关于 \(E(s,t)\) 的方程
\[(1-p_i)(1-p_j)E(u,v)+(1-p_i)p_jE(u,j)+p_i(1-p_j)E(i,v)+(p_ip_j-1)E(i,j)+1=0,u\in Edge(i,u),v\in Edge(j,v)\]

Code

/**************************************************************
Problem: 3270
User: BeiYu
Language: C++
Result: Accepted
Time:376 ms
Memory:3104 kb
****************************************************************/ #include<cstdio>
#include<cmath>
#include<iostream>
using namespace std;
#define H(i,j) (i*n+j)
inline int in(int x=0,char ch=getchar()){ while(ch>'9'||ch<'0') ch=getchar();
while(ch>='0'&&ch<='9') x=(x<<3)+(x<<1)+ch-'0',ch=getchar();return x; }
const int N = 22;
int n,m,s,t;bool b[N][N];
double p[N],a[N*N][N*N];int du[N];
void init(){
for(int i=0;i<n;i++)
for(int j=0;j<n;j++)
for(int u=0;u<n;u++) if(b[i][u])
for(int v=0;v<n;v++) if(b[j][v]&&u!=v){
int h1=H(i,j),h2=H(u,v);
if(i==u&&j==v) a[h1][h2]+=p[u]*p[v];
else if(i==u) a[h1][h2]+=p[u]*(1-p[v])/du[v];
else if(j==v) a[h1][h2]+=(1-p[u])*p[v]/du[u];
else a[h1][h2]+=(1-p[u])*(1-p[v])/du[u]/du[v];
}
for(int i=0;i<n*n;i++) a[i][i]-=1;
} void gauss(int n){
for(int i=0,r,j,k;i<n;i++){
for(r=i,j=i+1;j<n;j++) if(fabs(a[r][i])<fabs(a[j][i])) r=j;
if(r!=i) for(j=0;j<=n;j++) swap(a[r][j],a[i][j]);
for(j=i+1;j<n;j++){
double bas=a[j][i]/a[i][i];
for(k=i;k<=n;k++) a[j][k]-=bas*a[i][k];
}
}
for(int i=n-1;~i;i--){
for(int j=i+1;j<n;j++) a[i][n]-=a[j][n]*a[i][j];
a[i][n]/=a[i][i];
}
} int main(){
n=in(),m=in(),s=in()-1,t=in()-1;
for(int i=1,u,v;i<=m;i++) u=in()-1,v=in()-1,b[u][v]=b[v][u]=1,du[u]++,du[v]++;
for(int i=0;i<n;i++) scanf("%lf",&p[i]),b[i][i]=1;
a[H(s,t)][n*n]=-1;init();
// for(int i=0;i<n*n;i++)
// for(int j=0;j<=n*n;j++)
// printf("%.6lf%c",a[i][j]," \n"[j==n*n]);
// putchar('\n');
gauss(n*n);
// for(int i=0;i<n*n;i++)
// for(int j=0;j<=n*n;j++)
// printf("%.6lf%c",a[i][j]," \n"[j==n*n]);
// putchar('\n');
for(int i=0;i<n;i++) printf("%.6lf ",a[H(i,i)][n*n]);
return 0;
}

  

BZOJ 3270: 博物馆的更多相关文章

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

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

  2. ●BZOJ 3270 博物馆

    题链: http://www.lydsy.com/JudgeOnline/problem.php?id=3270题解: 期望DP,高斯消元 本来是定义的关于概率的dp, 但是发现这样定义有很多解释不通 ...

  3. bzoj 3270 博物馆(高斯消元)

    [题意] 两人起始在s,t点,一人pi概率选择留在i点或等概率移动,问两人在每个房间相遇的概率. [思路] 把两个合并为一个状态,(a,b)表示两人所处的状态,设f[i]为两人处于i状态的概率.则有转 ...

  4. BZOJ 3270 博物馆 && CodeForces 113D. Museum 期望概率dp 高斯消元

    大前提,把两个点的组合看成一种状态 x 两种思路 O(n^7) f[x]表示在某一个点的前提下,这个状态经过那个点的概率,用相邻的点转移状态,高斯一波就好了 O(n^6) 想象成臭气弹,这个和那个的区 ...

  5. BZOJ 3270 博物馆 ——概率DP 高斯消元

    用$F(i,j)$表示A在i,B在j的概率. 然后很容易列出转移方程. 然后可以高斯消元了! 被一个问题困扰了很久,为什么起始点的概率要加上1. (因为其他博客上都是直接写成-1,雾) 考虑初始状态是 ...

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

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

  7. BZOJ 3270: 博物馆 概率与期望+高斯消元

    和游走挺像的,都是将概率转成期望出现的次数,然后拿高斯消元来解. #include <bits/stdc++.h> #define N 23 #define setIO(s) freope ...

  8. BZOJ 3270 && BZOJ 1778 (期望DP && 高斯消元)

    BZOJ 3270 :设置状态为Id(x,y)表示一人在x,一人在y这个状态的概率. 所以总共有n^2种状态. p[i]表示留在该点的概率,Out[i]=(1-p[i])/Degree[i]表示离开该 ...

  9. 「BZOJ 3270」博物馆「高斯消元」

    应该算高斯消元经典题了吧. 题意:一个无向连通图,有两个人分别在\(s,t\),若一个人在\(u\),每一分钟有\(p[u]\)的概率不动,否则随机前往一个相邻的结点,求在每个点相遇的概率 题解: 首 ...

随机推荐

  1. 基础SQL语句

    SQL语句: 1.插入 方法一: "INSERT INTO [DB].[dbo].[T_Table] ([ID],[Name],[Amount],[Creater],[CreatedOn], ...

  2. js日期加减

    先补充下基础知识: var myDate = new Date(); //myDate默认返回当前时间 myDate.getYear(); //获取当前年份(2位) myDate.getFullYea ...

  3. Timer类和TimerTask类

    Timer类是一种线程设施,可以用来实现在某一个时间或某一段时间后安排某一个任务执行一次或定期重复执行. 该功能要与TimerTask类配合使用.TimerTask类用来实现由Timer安排的一次或重 ...

  4. You Can Do Research Too

    You Can Do Research Too I was recently discussing gatekeeping and the process of getting started in ...

  5. draw9的使用说明

    转载来自:http://isux.tencent.com/android-ui-9-png.html 在Android的设计过程中,为了适配不同的手机分辨率,图片大多需要拉伸或者压缩,这样就出现了可以 ...

  6. Saltstack pillar组件

     pillar组件 pillar也是Saltstack最重要的组件之一,其作用是定义与被控主机相关的任何数据,定义好的数据可以被其他组件使用,如模板.state.API等.在pillar中定义的数据与 ...

  7. safari 调用隐藏fileInput

    在safari上,用自定义按钮调用隐藏fileInput,注意点 1. event listener中,不要 return false2. 不要使用display:none,可使用 opacity:0 ...

  8. ASP.NET MVC使用Bootstrap系列(3)——使用Bootstrap 组件

    阅读目录 Bootstrap 导航条 列表组 徽章 媒体对象 页头 路径导航 分页 输入框组 按钮式下拉菜单 警告框 进度条 小结 Bootstrap为我们提供了十几种的可复用组件,包括字体图标.下拉 ...

  9. iOS数据库学习(1)-安装Navicat

    1.下载Navicat Premium 11.0.16.dmg 已经放到百度网盘,里面有安装文件和注册机 下载链接: http://pan.baidu.com/s/1sjI64HZ  密码: 2h7q ...

  10. C#对HTML文档的解析

    http://www.2cto.com/kf/201312/268777.html http://jingyan.baidu.com/article/7e44095334bb162fc0e2efad. ...