BZOJ3270 博物館 概率DP 高斯消元

@(XSY)[概率DP, 高斯消元]

Description

有一天Petya和他的朋友Vasya在进行他们众多旅行中的一次旅行,他们决定去参观一座城堡博物馆。这座博物馆有着特别的样式。它包含由m条走廊连接的n间房间,并且满足可以从任何一间房间到任何一间别的房间。
两个人在博物馆里逛了一会儿后两人决定分头行动,去看各自感兴趣的艺术品。他们约定在下午六点到一间房间会合。然而他们忘记了一件重要的事:他们并没有选好在哪儿碰面。等时间到六点,他们开始在博物馆里到处乱跑来找到对方(他们没法给对方打电话因为电话漫游费是很贵的)
不过,尽管他们到处乱跑,但他们还没有看完足够的艺术品,因此他们每个人采取如下的行动方法:每一分钟做决定往哪里走,有Pi 的概率在这分钟内不去其他地方(即呆在房间不动),有1-Pi 的概率他会在相邻的房间中等可能的选择一间并沿着走廊过去。这里的i指的是当期所在房间的序号。在古代建造是一件花费非常大的事,因此每条走廊会连接两个不同的房间,并且任意两个房间至多被一条走廊连接。
两个男孩同时行动。由于走廊很暗,两人不可能在走廊碰面,不过他们可以从走廊的两个方向通行。(此外,两个男孩可以同时地穿过同一条走廊却不会相遇)两个男孩按照上述方法行动直到他们碰面为止。更进一步地说,当两个人在某个时刻选择前往同一间房间,那么他们就会在那个房间相遇。
两个男孩现在分别处在a,b两个房间,求两人在每间房间相遇的概率。

Input

第一行包含四个整数,n表示房间的个数;m表示走廊的数目;a,b (1 ≤ a, b ≤ n),表示两个男孩的初始位置。
之后m行每行包含两个整数,表示走廊所连接的两个房间。
之后n行每行一个至多精确到小数点后四位的实数 表示待在每间房间的概率。
题目保证每个房间都可以由其他任何房间通过走廊走到。

Output

输出一行包含n个由空格分隔的数字,注意最后一个数字后也有空格,第i个数字代表两个人在第i间房间碰面的概率(输出保留6位小数)
注意最后一个数字后面也有一个空格

Sample Input

2 1 1 2
1 2
0.5
0.5

Sample Output

0.500000 0.500000

HINT

对于100%的数据有 n <= 20,n-1 <= m <= n(n-1)/2

Solution

令\(f_{x, y}\)表示連個男孩在结束游览前分別到达\(x\), \(y\)房間的概率, 則有如下轉移方程:
\[f_{x, y} = p_x * p_y * f_{x, y} + \frac{(1 - p_i) * p_y}{cnt_i} * f_{i, y} + \frac{(1 - p_j) * p_x}{cnt[j]} * f_{x, j} + \frac{(1 - p_i) * (i - p_j)}{(1 - cnt_i) * (1 - cnt_j)} * p_{i, j}\]意思是分開三類情況討論, 第一類情況是兩個人都已經在\((x, y)\)的狀態下, 則下一個狀態還是在\((x, y)\)的概率為\[p_x * p_y * f_{x, y}\]; 第二類情況是其中一個人已經在\(x\)或\(y\)點, 另外一個人要走過來, 概率為\[\frac{(1 - p_i) * p_y}{cnt_i} * f_{i, y} + \frac{(1 - p_j) * p_x}{cnt[j]} * f_{x, j}\]; 第三類情況是兩個人都要從別處走過來, 則概率為\[ \frac{(1 - p_i) * (i - p_j)}{(1 - cnt_i) * (1 - cnt_j)} * p_{i, j}\]
移項得到最終需要的方程.
注意这里的结束条件是两个人同时出现在一个房间里, 所以方程不能 \(i == j\) 的状态转移而来, 因而系数要特判为\(0\)
在代碼實現的時候, 可以枚舉每一對\((x, y)\)和對應的\((i, j)\)以得到方程.
设定起点的写法要注意, 已经在代码中注明.

#include <cmath>
#include <cstdio>
#include <iostream>
using namespace std;const int siz = 1 << 5;int n, m, a, b, cnt[siz], map[siz][siz], id[siz][siz];double p[siz], f[siz*siz][siz*siz];inline int pos(int x, int y)
{return (x - 1) * n + y;
}int main()
{scanf("%d%d%d%d", &n, &m, &a, &b);for (int i = 1, x, y; i <= m; ++i){scanf("%d%d", &x, &y);map[x][y] = true;map[y][x] = true;++cnt[x];++cnt[y];}for (int i = 1; i <= n; ++i)scanf("%lf", p + i), map[i][i] = 1;int tot = 0;for (int i = 1; i <= n; ++i)for (int j = 1; j <= n; ++j)id[i][j] = ++tot;for (int i = 1; i <= n; ++i)for (int j = 1; j <= n; ++j){f[id[i][j]][id[i][j]] = -1.0;for (int k = 1; k <= n; ++k)for (int l = 1; l <= n; ++l)if (k != l){int x = id[i][j];int y = id[k][l];if (map[k][i] && map[l][j]){if (k == i && l == j)f[x][y] += p[k]*p[l];if (k != i && l == j)f[x][y] += (1.0 - p[k]) / cnt[k] * p[l];if (k == i && l != j)f[x][y] += (1.0 - p[l]) / cnt[l] * p[k];if (k != i && l != j)f[x][y] += (1.0 - p[k]) / cnt[k] * (1.0 - p[l]) / cnt[l];}}}f[id[a][b]][id[n][n] + 1] = -1.0;   //因為開始時(a, b)的概率為1, 所以移項得到等式右邊為- 1 int mx = id[n][n] + 1;for (int i = 1; i < mx; ++i){int r = i;for (int j = i + 1; j < mx; ++j)if (fabs(f[j][i]) > fabs(f[r][i]))r = j;swap(f[i], f[r]);for (int j = i + 1; j < mx; ++j){long double t = f[j][i] / f[i][i];for (int k = i; k <= mx; ++k)f[j][k] -= t * f[i][k];}}for (int i = mx - 1; i >= 0; --i){for (int j = i + 1; j < mx; ++j)f[i][mx] -= f[j][mx] * f[i][j];f[i][mx] /= f[i][i];}for (int i = 1; i <= n; ++i)printf("%.6lf ", f[id[i][i]][id[n][n] + 1]);
}

转载于:https://www.cnblogs.com/ZeonfaiHo/p/6418815.html

BZOJ3270 博物館 概率DP 高斯消元相关推荐

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

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

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

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

  3. BZOJ 3270: 博物馆 1778: 驱逐猪猡 【概率DP+高斯消元】

    题目描述: 中文题面,不多解释.1778传送门 3270 传送门 (博物馆)题目分析: 也许很多人做概率题的时候都有种虚幻感..感觉莫名其妙就得出一个期望.概率,一知半解... 所以我在这里仔细地剖析 ...

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

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

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

    [BZOJ3640]JC的小苹果 Description 让我们继续JC和DZY的故事. "你是我的小丫小苹果,怎么爱你都不嫌多!" "点亮我生命的火,火火火火火!&qu ...

  6. AC自动机 + 概率dp + 高斯消元 --- HDU 5955 or 2016年沈阳icpc H [AC自动机 + 概率dp + 高斯消元]详解

    题目链接 题目大意: 就是有NNN个人,每个人都会猜一个长度为LLL的只包含{1,2,3,4,5,6}\{1,2,3,4,5,6\}{1,2,3,4,5,6}的序列,现在裁判开始投掷骰子,并且把每次的 ...

  7. hdu4418 概率dp+高斯消元(近日吐槽)

    因为过年,好久没更博客了,最近要狂补题解了== 1.做了几天的概率dp,稍后还要写一篇概率dp和期望的总结,当然,下面几天的专题还是概率dp 2.接着还要整理一个漂亮的高斯消元模板= 3.最近打了几场 ...

  8. bzoj 4820: [Sdoi2017]硬币游戏 概率dp+高斯消元+KMP

    题意 周末同学们非常无聊,有人提议,咱们扔硬币玩吧,谁扔的硬币正面次数多谁胜利. 大家纷纷觉得这个游戏非常符合同学们的特色,但只是扔硬币实在是太单调了. 同学们觉得要加强趣味性,所以要找一个同学扔很多 ...

  9. [BZOJ5292][BJOI2018]治疗之雨(概率DP+高斯消元)

    https://blog.csdn.net/xyz32768/article/details/83217209 不难找到DP方程与辅助DP方程,发现DP方程具有后效性,于是高斯消元即可. 但朴素消元显 ...

最新文章

  1. 脚踏实地,自强不息——清华大学大数据软件团队2021年度先进个人风采展示
  2. React + Typescript + Webpack 开发环境配置
  3. 吴恩达深度学习笔记8-Course3-Week1【机器学习策略(ML Strategy)1】
  4. OpenGL Draw TransformFeedback 绘制变换反馈的实例
  5. Android之webview背景设置为透明无效
  6. 探地雷达系统行业调研报告 - 市场现状分析与发展前景预测
  7. 50k热敏电阻温度对照表c语言,50K热敏电阻温度表
  8. 蓝牙协议层 GATT ,GAP,ATT 之间的关系
  9. 理论+故事,开启你的量化阅读之旅
  10. 唐诗赏析--唐诗的起源,发展
  11. HTML+CSS案例京东静态界面
  12. vb.net 编写的简易串口调试程序
  13. 大脑--物质与意识之综合体,是物质有双重现象(物性与灵性)的实证
  14. springboot 将本地引用的lib一起打包
  15. win10右键卡顿原因_windows10鼠标点击右键出现卡顿如何解决
  16. GitHub 的 2021 年度报告,全球程序员好像都在卷呐!
  17. weui学习总结——1、weui表单常用标签
  18. python获取路由器信息_python 3.5实现检测路由器流量并写入txt的方法实例
  19. 2020年最值得加入的互联网公司有哪些?
  20. OMNET++ INET框架学习教程(一)

热门文章

  1. Java爬虫框架:Jvppeteer
  2. 用ps临摹丰田logo
  3. 股权激励:用明天的钱激励今天的员工
  4. 苹果手机怎样设置才运行速度快?
  5. 2021年全球FCC催化剂添加剂收入大约423.9百万美元,预计2028年达到506.8百万美元
  6. python 防止反编译的办法
  7. 链游PlaceWar完成300万美元战略融资,新兴热门币PLACE
  8. 【基础算法训练】——贪心
  9. ChromeDriver版本(最新v2.45)与Chrome版本(最新v72)支持关系
  10. Echarts中条形统计图设置两条数据展示效果-图例样式位置设置