题目大意:

有一个连通的迷宫,你可以理解为一个 $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相关推荐

  1. 【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 ...

  2. [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 ...

  3. D. DZY Loves Modification

    D. DZY Loves Modification time limit per test 2 seconds memory limit per test 256 megabytes input st ...

  4. Codeforces Round #FF 446 C. DZY Loves Fibonacci Numbers

    參考:http://www.cnblogs.com/chanme/p/3843859.html 然后我看到在别人的AC的方法里还有这么一种神方法,他预先设定了一个阈值K,当当前的更新操作数j<K ...

  5. Codeforces 447C - DZY Loves Sequences

    447C - DZY Loves Sequences 思路:dp 代码: #include<bits/stdc++.h> using namespace std; #define ll l ...

  6. Codeforces 446C —— DZY Loves Fibonacci Numbers(线段树)

    题目:DZY Loves Fibonacci Numbers 题意比較简单,不解释了. 尽管官方的题解也是用线段树,但还利用了二次剩余. 可是我没有想到二次剩余,然后写了个感觉非常复杂度的线段树,还是 ...

  7. CF A. DZY Loves Hash

    A. DZY Loves Hash time limit per test 1 second memory limit per test 256 megabytes input standard in ...

  8. 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) ...

  9. HDU 5646 DZY Loves Partition

    题目链接: hdu:http://acm.hdu.edu.cn/showproblem.php?pid=5646 bc:http://bestcoder.hdu.edu.cn/contests/con ...

最新文章

  1. 爱情,这种高级玩意儿--一个码农的自白
  2. golang实现图片上传和下载
  3. c语言delay_利用C语言编程单片机,制作可以根据环境光照调整亮度的智能灯
  4. JavaScript三种创建构造函数的方式
  5. 【转】c# 操作webservice(经典入门教程+MSDN必胜)(有自己修改的部分)
  6. define定义的是什么类型_为什么Django 3后建议使用Field.choices枚举类型定义choices选项...
  7. oracle10g备份导入
  8. 苏州科技学院计算机组成原理考试,苏州科技学院计算机组成原理复习提纲.doc...
  9. Jquery学习总结(7)——JQuery常用的10个方法总结
  10. Docker的C/S模式
  11. vb计算机二级操作题考试试题,计算机二级考试《VB》操作试题及答案2016
  12. C语言三种形式编九九乘法表,C语言九九乘法表(五种输出形式)
  13. python音频转文字腾讯_Python生成腾讯云实时音视频的UserSig签名
  14. 安卓sqlite的使用
  15. ASP.NET mvcConf Videos Available
  16. 正方教务系统换数据库服务器,自己山寨正方教务系统数据库连接解密程序
  17. 计算组合C(m,n)的计算方法(C++篇)
  18. 对CreateCompatibleDC的粗浅认识
  19. 北京航空航天大学 素数(java)
  20. Amount of Degrees

热门文章

  1. 阿里云大数据ACA总结
  2. java判断对象属性为空_Java判断对象属性全为空
  3. 华为HCIA鲲鹏生态体系介绍
  4. Revit SDK 介绍:API Sketched Winder Stairs 创建扇形踏步楼梯
  5. java使用aspose实现Excel转PDF加入密码保护并解密
  6. 成功需要培养独特的眼光,芸赞通天下沈杨
  7. Python+OpenCV教程3:打开摄像头
  8. pybind11中文资料(第五章 面向对象的代码)
  9. 记一次CRM敏捷认证培训学习总结
  10. html统计表合并单元格的快捷键,excel中合并单元格的快捷键的方法及设置技巧