CF446D DZY Loves Games

高斯消元好题

如果暴力地,令f[i][k]表示到i,有k条命的概率,就没法做了。

转化题意

生命取决于经过陷阱的个数

把这个看成一步

所以考虑从一个陷阱到另一个陷阱,不经过其他陷阱的概率p[i][j]

当然1出发到其他陷阱的概率也要得到。

然后相当于有一个新图,

从1出发,走k-1步恰好到n的概率

暴力方法:

枚举一个出发点s,

则$P_x=\sum_{v&&v!=trap}P_v/deg_v+P(x is a start)$

特别地,v是s也可以转移(虽然s可能是陷阱,但是是出发点)

O(n^4)

考虑优化

其实所有的系数都是一样的。只是常数项不一样。即$P(x is a start)$不同。

什么,你说对于某些s是trap,但是作为出发点可以转移这里不同的s条件不同?

我们可以枚举s的出点v,直接把v作为出发点,概率是1/deg(s)

所以,我们可以把常数项扔到等号后面,堆成长度为陷阱数量的向量。

一起带着消即可。

#include<bits/stdc++.h>
#define numb (ch^'0')
#define il inline
#define reg register int
using namespace std;
typedef long long ll;
template<class T>il void rd(T &x){
x=;char ch;bool fl=false;
while(!isdigit(ch=getchar()))(ch=='-')&&(fl=true);
for(x=numb;isdigit(ch=getchar());x=x*+numb);
(fl==true)&&(x=-x);
}
template<class T>il void prt(T a[],int st,int nd){
for(reg i=st;i<=nd;++i) cout<<a[i]<<" ";cout<<endl;
}
namespace Miracle{
const int N=;
int has[N],con[N][N];
int du[N];
int id[N],mem[N],num;
double f[N][N];
double p[N][N]; int n,m,T;
void guass(int typ,int c){
// cout<<" guass "<<endl;
// for(reg i=1;i<=n;++i){
// for(reg j=1;j<=n+c;++j){
// cout<<f[i][j]<<" ";
// }cout<<endl;
// } for(reg i=;i<=n;++i){
int id=i;
for(reg j=i+;j<=n;++j){
if(fabs(f[j][i])>fabs(f[id][i])) id=j;
}
if(id!=i){
for(reg j=i;j<=n+c;++j){
swap(f[i][j],f[id][j]);
}
}
for(reg j=i+;j<=n;++j){
if(fabs(f[j][i])>){
double lp=f[j][i]/f[i][i];
for(reg k=i;k<=n+c;++k){
f[j][k]-=f[i][k]*lp;
}
}
}
}
if(typ!=){
for(reg i=n;i>=;--i){
for(reg j=i+;j<=n;++j){
if(fabs(f[i][j])>){
for(reg k=n+;k<=n+c;++k){
f[i][k]-=f[i][j]*p[k-n][j];
}
}
}
for(reg k=n+;k<=n+c;++k){
p[k-n][i]=f[i][k]/f[i][i];
}
}
}else{
// for(reg i=1;i<=n;++i){
// for(reg j=1;j<=n+c;++j){
// cout<<f[i][j]<<" ";
// }cout<<endl;
// }
for(reg i=n;i>=;--i){
for(reg j=i+;j<=n;++j){
if(fabs(f[i][j])>){
f[i][n+]-=f[i][j]*p[][j];
}
}
p[][i]=f[i][n+]/f[i][i];
}
}
}
struct tr{
double a[][];
tr(){memset(a,,sizeof a);}
void init(){
for(reg k=;k<=num;++k){
a[k][k]=1.00;
}
}
tr friend operator *(const tr &a,const tr &b){
tr c;
for(reg k=;k<=num;++k){
for(reg i=;i<=num;++i){
for(reg j=;j<=num;++j){
c.a[i][j]+=a.a[i][k]*b.a[k][j];
}
}
}
return c;
}
}S,B;
tr qm(tr B,int y){
tr ret;ret.init();
while(y){
if(y&) ret=ret*B;
B=B*B;
y>>=;
}
return ret;
} int main(){
rd(n);rd(m);rd(T);
for(reg i=;i<=n;++i){
rd(has[i]);
if(has[i]) mem[++num]=i,id[i]=num;
}
int x,y;
for(reg i=;i<=m;++i){
rd(x);rd(y);
++du[x];++du[y];
++con[x][y];++con[y][x];
}
for(reg i=;i<=n;++i){
f[i][i]=1.000;
for(reg j=;j<=n;++j){
if(j==i) continue;
if(!has[j]&&con[i][j]){
f[i][j]=-(double)con[i][j]/du[j];
}
}
if(i==) f[i][n+]=1.00;
}
guass(,); // for(reg i=1;i<=num;++i){
// cout<<" memi "<<i<<" : "<<mem[i]<<" "<<p[0][mem[i]]<<endl;
// } memset(f,,sizeof f); for(reg i=;i<=n;++i){
f[i][i]=1.000;
for(reg j=;j<=n;++j){
if(j==i) continue;
if(!has[j]&&con[i][j]){
f[i][j]=-(double)con[i][j]/du[j];
}
}
for(reg j=;j<=num;++j){
if(mem[j]==i) continue;
if(con[mem[j]][i]){
f[i][j+n]=(double)con[mem[j]][i]/du[mem[j]];
}
}
}
guass(,num);
for(reg j=;j<=num;++j){
B.a[][j]=p[][mem[j]];
}
for(reg i=;i<=num;++i){
for(reg j=;j<=num;++j){
B.a[i][j]=p[i][mem[j]];
}
}
// B.a[num][num]=1.00; // for(reg i=0;i<=num;++i){
// for(reg j=0;j<=num;++j){
// cout<<B.a[i][j]<<" ";
// }cout<<endl;
// } S.a[][]=1.00;
S=S*qm(B,T-); printf("%.10lf",S.a[][num]);
return ;
} }
signed main(){
Miracle::main();
return ;
}

只关心生命值多少

题意转化!变成新图!

系数相同,带着常数一起消除!

CF446D DZY Loves Games的更多相关文章

  1. 【CF446D】DZY Loves Games 高斯消元+矩阵乘法

    [CF446D]DZY Loves Games 题意:一张n个点m条边的无向图,其中某些点是黑点,1号点一定不是黑点,n号点一定是黑点.问从1开始走,每次随机选择一个相邻的点走过去,经过恰好k个黑点到 ...

  2. 【CF446D】DZY Loves Games

    题解: 不错的题目 首先要求的黑点个数非常多 比较容易想到矩阵乘法 于是我们可以求出从某个黑点出发到任意一个黑点之间的概率 发现不同出发点带来的变化只有常数项 于是我们可以预处理出从每个方程转移的系数 ...

  3. Codeforces 446D - DZY Loves Games(高斯消元+期望 DP+矩阵快速幂)

    Codeforces 题目传送门 & 洛谷题目传送门 神仙题,%%% 首先考虑所有格子都是陷阱格的情况,那显然就是一个矩阵快速幂,具体来说,设 \(f_{i,j}\) 表示走了 \(i\) 步 ...

  4. D. DZY Loves Modification

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

  5. Codeforces Round #FF (Div. 2) D. DZY Loves Modification 优先队列

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

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

  7. Codeforces Round #FF (Div. 1) B. DZY Loves Modification 优先队列

    B. DZY Loves Modification 题目连接: http://www.codeforces.com/contest/446/problem/B Description As we kn ...

  8. Codeforces Round #FF (Div. 1) B. DZY Loves Modification

    枚举行取了多少次,如行取了i次,列就取了k-i次,假设行列单独贪心考虑然后相加,那么有i*(k-i)个交点是多出来的:dpr[i]+dpc[k-i]-i*(k-i)*p 枚举i取最大值.... B. ...

  9. CF446B DZY Loves Modification 优先队列

    As we know, DZY loves playing games. One day DZY decided to play with a n × m matrix. To be more pre ...

随机推荐

  1. Asp.Net页面间传值常见的几种方法

    一.QueryString QueryString是一种非常简单的传值方式,他是将传送的值显示在浏览器的地址栏中.如果是传递一个或多个安全性要求不高或是结构简单的数值时,可以使用这个方法.但是对于传递 ...

  2. tom

    题目描述 众所周知,Tom 猫对香肠非常感兴趣.有一天,Tom 家里的女主人赏给了Tom 一大堆香肠.这些香肠太多了,以至于Tom 一顿吃不完,于是它把这些香肠串成了一棵树,树的每个节点上都有一个香肠 ...

  3. java并发编程笔记(六)——AQS

    java并发编程笔记(六)--AQS 使用了Node实现FIFO(first in first out)队列,可以用于构建锁或者其他同步装置的基础框架 利用了一个int类型表示状态 使用方法是继承 子 ...

  4. Map-Amap:目录

    ylbtech-Map-Amap:目录 1. 高德地图返回顶部 1. https://www.amap.com/ 2. 2.  高德地图App返回顶部 1. http://www.autonavi.c ...

  5. Python 进阶_OOP 面向对象编程_实例属性和方法

    目录 目录 构造器和解构器 构造器 __init__ 真构造器 __new__ 解构器 __del__ 实例方法 Python 中的 抽象方法 实例属性 查看实例属性 实例属性和类属性的区别 访问不可 ...

  6. xshell的安装及连接linux的使用方法

    版权声明:本文为博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明.本文链接:https://blog.csdn.net/lx_Frolf/article/deta ...

  7. js判断客户端是pc还是移动端

    navigator.userAgentNavigator 对象包含有关浏览器的信息.没有应用于 navigator 对象的公开标准,不过所有浏览器都支持该对象.userAgent 属性是一个只读的字符 ...

  8. 转 cpu高 问题分析定位

    文章来源: http://www.blogjava.net/hankchen/archive/2012/08/09/377735.html 一个应用占用CPU很高,除了确实是计算密集型应用之外,通常原 ...

  9. maxim - Android UI压力测试

    项目介绍 项目地址:https://github.com/zhangzhao4444/Maxim 与monkey对比优势: 快 稳:只进行有意义的操作,防误点状态栏,不会乱断网.卸载应用 支持脱机运行 ...

  10. etcd扩展使用

    etcd我已经提到很多次了,前面的可以自己查看.v3版本改用grpc接口,很简单,非常简单,易上手易学习. etcd有集群部署方式,那么就涉及部署的地址,可以动态添加部署节点,这样再应用中不可能都去关 ...