题面

传送门

思路

本题的点数很少,只有20个

考虑用二元组$S=(u,v)$表示甲在$u$点,乙在$v$点的状态

那么可以用$f(S)$表示状态$S$出现的概率

不同的$f$之间的转移就是通过边

转移有4种情况

对于$S=(u,v)$来说,有以下四种转移:

转移一,甲乙都选择不动,此时从$S$转移到$S$,概率为$p[u]*p[v]$

转移二,甲动乙不动,此时从$S$转移到$S'=(u',v)$,其中$u'$是异于$u$并与$u$相连的点,概率为$\frac{1-p[u]}{deg[u]}*p[v]$,其中$deg[i]$表示$i$的度数

转移三,甲不动乙动,同转移二

转移四,甲乙都动,此时从$S$转移到$S'=(u',v')$,概率为$\frac{1-p[u]}{deg[u]}\ast\frac{1-p[v]}{deg[v]}$

写完转移,发现这个图因为是联通的,所以状态之间的转移会连成一个环

这时需要用到高斯消元

构建nn个nn元方程,每个未知数对应一种状态$S$,那么每一项的系数就是上述的转移概率了

需要注意的有两点

第一,$S=(u,u)$转移到自己是没有概率的,因为这个状态已经停下了,不会再转移了

第二,出发节点的那个方程表达式的值是1,代表一个初始元位置在出发点这里

Code

```cpp

include

include

include

include

include

include

define id(i,j) (i-1)*n+j

define ll long long

using namespace std;
inline int read(){
int re=0,flag=1;char ch=getchar();
while(ch>'9'||ch<'0'){
if(ch=='-') flag=-1;
ch=getchar();
}
while(ch>='0'&&ch<='9') re=(re<<1)+(re<<3)+ch-'0',ch=getchar();
return reflag;
}
double a[510][510],p[110],deg[110],go[110],ans[510];
int n,m,op1,op2,cnt;
int first[110],cnte;
struct edge{
int to,next;
}e[1010];
inline void add(int u,int v){
deg[u]++;deg[v]++;
e[++cnte]=(edge){v,first[u]};first[u]=cnte;
e[++cnte]=(edge){u,first[v]};first[v]=cnte;
}
void Gauss(){
int i,j,k,num;double tmp;
for(i=1;i<=cnt;i++){
num=i;
for(j=i+1;j<=cnt;j++){
if(fabs(a[num][i])<fabs(a[j][i])) num=j;
}
if(num!=i) for(j=1;j<=cnt+1;j++) swap(a[i][j],a[num][j]);
for(j=i+1;j<=cnt;j++){
if(i!=j&&a[j][i]){
tmp=a[j][i]/a[i][i];
for(k=1;k<=cnt+1;k++) a[j][k]-=a[i][k]
tmp;
}
}
}
for(i=cnt;i>=1;i--){
for(j=i+1;j<=cnt;j++) a[i][cnt+1]-=a[i][j]ans[j];
ans[i]=a[i][cnt+1]/a[i][i];
}
}
int main(){
memset(first,-1,sizeof(first));
n=read();m=read();op1=read();op2=read();int i,j,t1,t2,u1,u2,v1,v2,tid;cnt=n
n;
for(i=1;i<=m;i++){
t1=read();t2=read();
add(t1,t2);
}
for(i=1;i<=n;i++) scanf("%lf",&p[i]),go[i]=(1.0-p[i])/deg[i];
for(u1=1;u1<=n;u1++){
for(u2=1;u2<=n;u2++){
tid=id(u1,u2);
a[tid][tid]=-1;
if(u1!=u2) a[tid][tid]+=p[u1]p[u2];
for(i=first[u1];~i;i=e[i].next){
v1=e[i].to;if(v1==u2) continue;
a[tid][id(v1,u2)]=go[v1]
p[u2];
}
for(i=first[u2];~i;i=e[i].next){
v2=e[i].to;if(v2==u1) continue;
a[tid][id(u1,v2)]=p[u1]go[v2];
}
for(i=first[u1];~i;i=e[i].next){
for(j=first[u2];~j;j=e[j].next){
v1=e[i].to;v2=e[j].to;if(v2==v1) continue;
a[tid][id(v1,v2)]=go[v1]
go[v2];
}
}
}
}
a[id(op1,op2)][cnt+1]-=1;
Gauss();
for(i=1;i<=n;i++) printf("%.6lf ",ans[id(i,i)]);
}
···

[bzoj3270] 博物馆 [期望+高斯消元]的更多相关文章

  1. BZOJ3270 博物馆(高斯消元+概率期望)

    将两个人各自所在点视为状态,新建一个图.到达某个终点的概率等于其期望次数.那么高斯消元即可. #include<iostream> #include<cstdio> #incl ...

  2. 【BZOJ】3143: [Hnoi2013]游走 期望+高斯消元

    [题意]给定n个点m条边的无向连通图,每条路径的代价是其编号大小,每个点等概率往周围走,要求给所有边编号,使得从1到n的期望总分最小(求该总分).n<=500. [算法]期望+高斯消元 [题解] ...

  3. 【BZOJ】2337: [HNOI2011]XOR和路径 期望+高斯消元

    [题意]给定n个点m条边的带边权无向连通图(有重边和自环),在每个点随机向周围走一步,求1到n的期望路径异或值.n<=100,wi<=10^9. [算法]期望+高斯消元 [题解]首先异或不 ...

  4. [BZOJ3143][HNOI2013]游走(期望+高斯消元)

    3143: [Hnoi2013]游走 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 3576  Solved: 1608[Submit][Status ...

  5. 【BZOJ3143】【HNOI2013】游走 && 【BZOJ3270】博物馆 【高斯消元+概率期望】

    刚学完 高斯消元,我们来做几道题吧! T1:[BZOJ3143][HNOI2013]游走 Description 一个无向连通图,顶点从1编号到N,边从1编号到M. 小Z在该图上进行随机游走,初始时小 ...

  6. bzoj3270 博物馆(期望+高斯消元)

    Time Limit: 30 Sec  Memory Limit: 128 MB 有一天Petya和他的朋友Vasya在进行他们众多旅行中的一次旅行,他们决定去参观一座城堡博物馆.这座博物馆有着特别的 ...

  7. BZOJ_3270_博物馆_(高斯消元+期望动态规划+矩阵)

    描述 http://www.lydsy.com/JudgeOnline/problem.php?id=3270 \(n\)个房间,刚开始两个人分别在\(a,b\),每分钟在第\(i\)个房间有\(p[ ...

  8. 【BZOJ3270】【高斯消元】博物馆

    Description 有一天Petya和他的朋友Vasya在进行他们众多旅行中的一次旅行,他们决定去参观一座城堡博物馆.这座博物馆有着特别的样式.它包含由m条走廊连接的n间房间,并且满足可以从任何一 ...

  9. BZOJ 3270: 博物馆 概率与期望+高斯消元

    和游走挺像的,都是将概率转成期望出现的次数,然后拿高斯消元来解. #include <bits/stdc++.h> #define N 23 #define setIO(s) freope ...

随机推荐

  1. POJ2409 Let it Bead(Polya定理)

    Let it Bead Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 6443   Accepted: 4315 Descr ...

  2. Java分享笔记:使用缓冲流复制文件

    [1] 程序设计 /*------------------------------- 1.缓冲流是一种处理流,用来加快节点流对文件操作的速度 2.BufferedInputStream:输入缓冲流 3 ...

  3. python基础数据类型之列表,元组操作

    一.列表的索引和切片1.列表的索引列表和字符串一样样拥有索引 lst = ["a","b","c"] print(lst[0]) # 获取第 ...

  4. JS获取元素属性和自定义属性

    获取元素的属性分为两种类型: 1-获取元素常见的属性(class,id,type,value……) 2-获取自定义的元素的属性(data-value,data-mess…….) 获取元素的属性,设置元 ...

  5. 协议 - OSI七层网络协议模型

    摘自:https://www.cnblogs.com/oneplace/p/5611094.html 互联网协议 本文全文转载阮一峰老师的两篇文章,自己做了一些添加内容 参考:互联网协议入门(一) 互 ...

  6. 无法打开物理文件 XXX.mdf“,操作系统错误 5:”5(拒绝访问。)"的解决办法

    http://blog.csdn.net/blackfield/article/details/6550499 用T-SQL命令附加数据库时,出现如下异常信息: 无法打开物理文件 XXX.mdf&qu ...

  7. Oracle 11g R2在 win7 64位的安装流程图解【含常见问题解决方案】

    ORACLE数据库系统是美国ORACLE公司(甲骨文)提供的以分布式数据库为核心的一组软件产品,是目前最流行的客户/服务器(CLIENT/SERVER)或B/S体系结构的数据库之一.Oracle 11 ...

  8. SSO 单点登录总结(PHP)

    本篇文章根据个人理解的知识整理汇总,如有不足之处,请大家多多指正. 单点登录(SSO--Single Sign On)的应用是很普遍的,尤其在大型网站系统中,比如百度,登录百度账号和,再转到百度经验. ...

  9. linux select用法

    select 是linux i/o 复用技术之一 man 2 select #include <sys/select.h> /* According to earlier standard ...

  10. B1005 继续(3n+1)猜想 (25分)

    B1005 继续(3n+1)猜想 (25分) 卡拉兹(Callatz)猜想已经在1001中给出了描述.在这个题目里,情况稍微有些复杂. 当我们验证卡拉兹猜想的时候,为了避免重复计算,可以记录下递推过程 ...