BZOJ3270:博物馆(高斯消元)
Description
Input
Output
Sample Input
1 2
0.5
0.5
Sample Output
HINT
对于100%的数据有 n <= 20,n-1 <= m <= n(n-1)/2
Solution
虽然是个sb题但是$1A$就很得劲了。因为省的调了
设$ans_{x,y}$表示第一个人在$x$点,第二个人在$y$点的概率。同时设$fx,fy$分别为$x$和$y$的相邻点,$d_i$表示$i$点的度数。
那么就有公式
$ans_{x,y}=p_x\times p_y\times ans_{x,y}$(两个人都停在原地)
$~~~~~~~~~~~~~~+(1-p_x)\times(1-p_y)\times\sum ans_{fx,fy}\times\frac{1}{d_{fx}\times d_{fy}}$(两个人都走)
$~~~~~~~~~~~~~~+p_x\times(1-p_y)\times\sum ans_{x,fy}\times\frac{1}{d_{fy}}$(只有第二个人走)
$~~~~~~~~~~~~~~+(1-p_x)\times p_y\times\sum ans_{fx,y}\times\frac{1}{d_{fx}}$(只有第一个人走)
把每一个$ans_{x,y}$看做一个未知数,然后就可以列出来$n^2$个方程组。高斯消元一下就可以求出来每一个$ans_{x,y}$了。
注意构造矩阵的时候可能状态$(fx,fy)$已经结束了(也就是$fx=fy$)所以不能从那里转移来。
Code
#include<iostream>
#include<cstdio>
#include<cmath>
#define N (409)
using namespace std; struct Node{int x,y;}A[N];
struct Edge{int to,next;}edge[N];
double f[N][N],ans[N],p[N];
int n,m,s,e,u,v,c,id_num,id[N][N];
int head[N],Ind[N],num_edge; void add(int u,int v)
{
Ind[v]++;
edge[++num_edge].to=v;
edge[num_edge].next=head[u];
head[u]=num_edge;
} void Build()
{
for (int i=; i<=c; ++i)
{
int x=A[i].x,y=A[i].y;
if (x!=y) f[i][i]=(-p[x]*p[y]);
else f[i][i]=;
for (int j=head[x]; j; j=edge[j].next)
for (int k=head[y]; k; k=edge[k].next)
{
int fx=edge[j].to,fy=edge[k].to;
if (fx==fy) continue;
f[i][id[fx][fy]]=-1.0/(Ind[fx]*Ind[fy])*(-p[fx])*(-p[fy]);
}
for (int j=head[x]; j; j=edge[j].next)
{
int fx=edge[j].to;
if (fx==y) continue;
f[i][id[fx][y]]=-1.0/(Ind[fx])*(-p[fx])*p[y];
}
for (int j=head[y]; j; j=edge[j].next)
{
int fy=edge[j].to;
if (x==fy) continue;
f[i][id[x][fy]]=-1.0/(Ind[fy])*p[x]*(-p[fy]);
}
if (x==s && y==e) f[i][c+]=;
}
} void Gauss()
{
for (int i=; i<=c; ++i)
{
int num=i;
for (int j=i+; j<=c; ++j)
if (fabs(f[j][i])>fabs(f[num][i])) num=j;
if (num!=i) swap(f[i],f[num]);
for (int j=i+; j<=c; ++j)
{
double t=f[j][i]/f[i][i];
for (int k=i; k<=c+; ++k)
f[j][k]-=t*f[i][k];
}
}
for (int i=c; i>=; --i)
{
for (int j=i+; j<=c; ++j)
f[i][c+]-=f[i][j]*ans[j];
ans[i]=f[i][c+]/f[i][i];
}
} int main()
{
scanf("%d%d%d%d",&n,&m,&s,&e);
for (int i=; i<=m; ++i)
{
scanf("%d%d",&u,&v);
add(u,v); add(v,u);
}
for (int i=; i<=n; ++i)
scanf("%lf",&p[i]);
for (int i=; i<=n; ++i)
for (int j=; j<=n; ++j)
{
id[i][j]=++c;
A[c]=(Node){i,j};
}
Build();
Gauss();
for (int i=; i<=n; ++i)
printf("%.6lf ",ans[id[i][i]]);
}
BZOJ3270:博物馆(高斯消元)的更多相关文章
- 【BZOJ-3270】博物馆 高斯消元 + 概率期望
3270: 博物馆 Time Limit: 30 Sec Memory Limit: 128 MBSubmit: 292 Solved: 158[Submit][Status][Discuss] ...
- 【BZOJ3143】【HNOI2013】游走 && 【BZOJ3270】博物馆 【高斯消元+概率期望】
刚学完 高斯消元,我们来做几道题吧! T1:[BZOJ3143][HNOI2013]游走 Description 一个无向连通图,顶点从1编号到N,边从1编号到M. 小Z在该图上进行随机游走,初始时小 ...
- 【BZOJ3270】【高斯消元】博物馆
Description 有一天Petya和他的朋友Vasya在进行他们众多旅行中的一次旅行,他们决定去参观一座城堡博物馆.这座博物馆有着特别的样式.它包含由m条走廊连接的n间房间,并且满足可以从任何一 ...
- BZOJ3270 博物馆(高斯消元+概率期望)
将两个人各自所在点视为状态,新建一个图.到达某个终点的概率等于其期望次数.那么高斯消元即可. #include<iostream> #include<cstdio> #incl ...
- BZOJ3270: 博物馆【概率DP】【高斯消元】
Description 有一天Petya和他的朋友Vasya在进行他们众多旅行中的一次旅行,他们决定去参观一座城堡博物馆.这座博物馆有着特别的样式.它包含由m条走廊连接的n间房间,并且满足可以从任何一 ...
- 【概率dp 高斯消元】bzoj3270: 博物馆
一类成环概率dp的操作模式 Description 有一天Petya和他的朋友Vasya在进行他们众多旅行中的一次旅行,他们决定去参观一座城堡博物馆.这座博物馆有着特别的样式.它包含由m条走廊连接的n ...
- bzoj3270 博物馆(期望+高斯消元)
Time Limit: 30 Sec Memory Limit: 128 MB 有一天Petya和他的朋友Vasya在进行他们众多旅行中的一次旅行,他们决定去参观一座城堡博物馆.这座博物馆有着特别的 ...
- [bzoj3270] 博物馆 [期望+高斯消元]
题面 传送门 思路 本题的点数很少,只有20个 考虑用二元组$S=(u,v)$表示甲在$u$点,乙在$v$点的状态 那么可以用$f(S)$表示状态$S$出现的概率 不同的$f$之间的转移就是通过边 转 ...
- BZOJ3270 博物館 概率DP 高斯消元
BZOJ3270 博物館 概率DP 高斯消元 @(XSY)[概率DP, 高斯消元] Description 有一天Petya和他的朋友Vasya在进行他们众多旅行中的一次旅行,他们决定去参观一座城堡博 ...
随机推荐
- 中国移动CMPP协议错误码
中国移动CMPP协议错误码 状态码 说明 出现次数高 DELIVRD 消息发送成功 用户成功接收到短信 REJECTD 消息因为某些原因被拒绝不 ...
- <Android 基础(二十五)> Frame Animation
简介 Frame Animation, 逐帧动画,通过定义一系列的Drawable对象来实现动画效果,可以用来作为视图的背景. Frame Animation在代码中体现为AnimationDrawa ...
- iPhone中调用WCF服务
本文介绍的是跨平台iPhone中调用WCF服务,WCF是由微软发展的一组数据通信的应用程序开发接口,它是.NET框架的一部分,由 .NET Framework 3.0+开始引入 iPhone中调用WC ...
- ecloipse背景修改豆沙
Eclipse背景色的修改 Eclipse背景色的修改,修改为豆沙色 值是85 123 205 一.修改编辑区 ①这个比较简单一般都会不多说. 1.首先点击Window 然后选择Preferen ...
- js原生实现轮播
前两天同事面试新人,让现场写”轮播的实现”.我一想这玩意貌似我也没写过啊,就在旁边暗搓搓地拖了一张纸也在那写,同事都纳闷了! 这玩意实现方法有很多种,就看喜欢那种,喜欢怎么写而已.我这里是通过对img ...
- JSON学习笔记-4
JSON 数组 1.访问数组 1.一次访问一个嵌套内容值var myObj, x; myObj = { "name":"网站", , "sites&q ...
- 请求包含(Include)和请求转发(Forward)
定义 请求包含是指将另一个Servlet的请求处理流程包含进来. 请求转发是指将请求转发给别的Servlet处理. 实现 实现请求包含和请求转发,可以使用HttpServletRequest的getR ...
- new 关键字
学习过的调用或者是执行函数的方式有几种? ①函数名+小括号 ②事件处理函数 ③定时器 ④数组里面的元素是函数,枚举出来执行 ⑤new关键字 提示:需要注意new 关键字需要在函数名前面使用 构造函数是 ...
- Pig limit用法举例
lmt = limit data 10; 只获取指定条数的数据,不能保证每次得到的结果一致,先执行order再limit可以保证一致. 输入数据全部载入. 会触发reduce阶段 a ...
- The directory '/home/stone/.cache/pip/http' or its parent directory is not owned by the current user and the cache has been disabled. Please check the permissions and owner of that directory. If execu
使用sudo pip install ......的时候出现下面一段黄色的代码: The directory '/home/stone/.cache/pip/http' or its parent d ...