CF446D. DZY Loves Games
题目大意:
有一个连通的迷宫,你可以理解为一个 $n$ 个点 $m$ 条边的无向连通图。有 些点可能有陷阱,保证 $1$ 号点没有陷阱而 $n$ 号点存在陷阱。一开始你有 $k$ 条命,每进入一个有陷阱的点你会损失一条命。
DZY听说这个游戏有一个隐藏关卡:如果进入 $n$ 号点时你恰好剩余 $2$ 条命, 你会先被扣除一条命,然后进入一个隐藏的极限关卡(在触发关卡之前 也可以一次或多次进入 $n$ 号点)。DZY很想进入这个关卡,但是他游戏水平不行,所以他的游戏策略是从 $1$ 号点开始,每次随机走到一个与当前点相邻的点。他想知道他能够触发隐藏关卡的概率,保留 $4$ 位小数。
算法标签:概率与期望dp,矩阵乘法
思路:
令 $a_u$ 为每个时刻在 $u$ 的概率之和,那么有
$$
a_u=\sum_{v\notin trap,(v,u)\in E}\frac{a_{v}}{deg(v)}+[u为起点的概率]
$$
因为我们这里设定令一个非陷阱的点作为起点,才不会算重,所以要限制只有非陷阱的才能转移到当前点。
$$
a_u-\sum_{v\notin traps,(v,u)\in E}\frac{a_v}{deg(v)}=[u为起点]
$$
根据这个式子就可以进行高斯消元了。
首先我们要计算从 $1$ 出发的方案走到各个陷阱的概率,那么除了 $1$ 为起点的概率为 $1$ 。
从一个陷阱走到另一个陷阱时,我们为了让他变成从一个非陷阱走出来,我们令它的所有出度作为起点的概率为 $\frac{1}{dev(u)}$ 。
发现这两类我们需要的式子除了常数项每一项的系数都相同,所以我们可以考虑合在一起计算。
计算出从一个陷阱走到另一个陷阱的概率之后,我们可以用矩阵乘法优化转移过程。
以下代码:
#include<bits/stdc++.h> #define il inline #define db double #define _(d) while(d(isdigit(ch=getchar()))) using namespace std; const int N=605,M=1e5+5; db f[N][N]; int u[M],v[M]; int n,m,k,d[N],id[N],num[N],tot; struct node{db a[105][105]; }s,t; il int read(){int x,f=1;char ch;_(!)ch=='-'?f=-1:f;x=ch^48;_()x=(x<<1)+(x<<3)+(ch^48);return f*x; } il void gauss(){for(int i=1;i<=n;i++){if(!f[i][i]){int mx=i;for(int j=i+1;j<=n;j++)if(fabs(f[j][i])>fabs(f[mx][i]))mx=j;if(mx^i)for(int j=i;j<=n+tot+1;j++)swap(f[mx][j],f[i][j]);}if(f[i][i]==0)continue;db tmp=f[i][i];for(int j=i;j<=n+tot+1;j++)f[i][j]/=tmp;for(int j=1;j<=n;j++)if(i^j&&f[j][i]!=0){tmp=f[j][i];for(int k=i;k<=n+tot+1;k++)f[j][k]-=tmp*f[i][k];}} } il node C(node x,node y){node z;for(int i=1;i<=tot;i++)for(int j=1;j<=tot;j++)z.a[i][j]=0;for(int i=1;i<=tot;i++)for(int j=1;j<=tot;j++)for(int k=1;k<=tot;k++)z.a[i][j]+=x.a[i][k]*y.a[k][j];return z; } il void ksm(int y){while(y){if(y&1)s=C(s,t);t=C(t,t);y>>=1;} } int main() {n=read();m=read();k=read();for(int i=1;i<=n;i++){id[i]=read();if(id[i])id[i]=++tot,num[tot]=i;}for(int i=1;i<=m;i++){u[i]=read();v[i]=read();d[u[i]]++;d[v[i]]++;}for(int i=1;i<=m;i++){int x=u[i],y=v[i];if(!id[x])f[y][x]-=1.0/d[x];else f[y][id[x]+n]+=1.0/d[x];if(!id[y])f[x][y]-=1.0/d[y];else f[x][id[y]+n]+=1.0/d[y];}f[1][1+tot+n]=1;for(int i=1;i<=n;i++)f[i][i]+=1;gauss();for(int i=1;i<=tot;i++)for(int j=1;j<=tot;j++)t.a[i][j]=f[num[j]][i+n];for(int i=1;i<=tot;i++)s.a[1][i]=f[num[i]][n+tot+1];ksm(k-2);printf("%lf\n",s.a[1][tot]);return 0; }
View Code
转载于:https://www.cnblogs.com/Jessie-/p/10600134.html
CF446D. DZY Loves Games相关推荐
- 【CF446B】 DZY Loves Modification
题目 题目描述 As we know, DZY loves playing games. One day DZY decided to play with a n×m n×m matrix. To b ...
- [CodeForces - 447D] D - DZY Loves Modification
D - DZY Loves Modification As we know, DZY loves playing games. One day DZY decided to play with a n ...
- D. DZY Loves Modification
D. DZY Loves Modification time limit per test 2 seconds memory limit per test 256 megabytes input st ...
- Codeforces Round #FF 446 C. DZY Loves Fibonacci Numbers
參考:http://www.cnblogs.com/chanme/p/3843859.html 然后我看到在别人的AC的方法里还有这么一种神方法,他预先设定了一个阈值K,当当前的更新操作数j<K ...
- Codeforces 447C - DZY Loves Sequences
447C - DZY Loves Sequences 思路:dp 代码: #include<bits/stdc++.h> using namespace std; #define ll l ...
- Codeforces 446C —— DZY Loves Fibonacci Numbers(线段树)
题目:DZY Loves Fibonacci Numbers 题意比較简单,不解释了. 尽管官方的题解也是用线段树,但还利用了二次剩余. 可是我没有想到二次剩余,然后写了个感觉非常复杂度的线段树,还是 ...
- CF A. DZY Loves Hash
A. DZY Loves Hash time limit per test 1 second memory limit per test 256 megabytes input standard in ...
- BZOJ 3309 DZY Loves Math
3309: DZY Loves Math Description 对于正整数n,定义f(n)为n所含质因子的最大幂指数.例如f(1960)=f(2^3 * 5^1 * 7^2)=3, f(10007) ...
- HDU 5646 DZY Loves Partition
题目链接: hdu:http://acm.hdu.edu.cn/showproblem.php?pid=5646 bc:http://bestcoder.hdu.edu.cn/contests/con ...
最新文章
- 爱情,这种高级玩意儿--一个码农的自白
- golang实现图片上传和下载
- c语言delay_利用C语言编程单片机,制作可以根据环境光照调整亮度的智能灯
- JavaScript三种创建构造函数的方式
- 【转】c# 操作webservice(经典入门教程+MSDN必胜)(有自己修改的部分)
- define定义的是什么类型_为什么Django 3后建议使用Field.choices枚举类型定义choices选项...
- oracle10g备份导入
- 苏州科技学院计算机组成原理考试,苏州科技学院计算机组成原理复习提纲.doc...
- Jquery学习总结(7)——JQuery常用的10个方法总结
- Docker的C/S模式
- vb计算机二级操作题考试试题,计算机二级考试《VB》操作试题及答案2016
- C语言三种形式编九九乘法表,C语言九九乘法表(五种输出形式)
- python音频转文字腾讯_Python生成腾讯云实时音视频的UserSig签名
- 安卓sqlite的使用
- ASP.NET mvcConf Videos Available
- 正方教务系统换数据库服务器,自己山寨正方教务系统数据库连接解密程序
- 计算组合C(m,n)的计算方法(C++篇)
- 对CreateCompatibleDC的粗浅认识
- 北京航空航天大学	素数(java)
- Amount of Degrees