传送门

题目大意:

一张无向图上有一只猫和一只老鼠,猫先走,鼠后走。猫每次会向与其相邻的并且距离老鼠最近的点移动(若距离相等去编号较小的),如果移动一步后还没吃到老鼠,还可以再移动一步(算在一个时间内的)。老鼠每次会向相邻的点移动或者不移动,所有选择的概率相同。问猫期望多少时间能够吃到老鼠。

题目分析:

期望dp:设\(f[i][j]\)表示猫在i点,鼠在j点,猫吃到鼠的期望步数。\(P[i][j]\)表示与i相邻的点中距离j最近且编号最小的点(bfs预处理)。\(deg[i]\)表示i的度数。

那么:$$f[i][j] = f[P[P[i][j]][j] / (deg[v] + 1) + \sum{f[P[P[i][j]][v_j] / (deg[v] + 1)} + 1$$

方程上面两式分别对应:

  1. 猫移动,鼠不移动。
  2. 猫移动,鼠移动。

    初始化:$$f[i][i] = 0$$

\[f[i][j] = 1(dis[i][j] \le 2)
\]

code

#include<bits/stdc++.h>
using namespace std;
const int N = 1050, M = 1050,OO = 0x3f3f3f3f;
#define eps 1e-8
int n, m, p, q, vt;
int ecnt, adj[N], nxt[M << 1], go[M << 1], P[N][N], dist[N][N], deg[N];
double f[N][N];
int vst[N];
struct node{
int now, dis;
node(){}
node(int _now, int _dis):now(_now), dis(_dis){}
}; inline void addEdge(int u, int v){
nxt[++ecnt] = adj[u], adj[u] = ecnt, go[ecnt] = v;
deg[u]++;
} inline void Bfs(int i){
static queue<node> que;
while(!que.empty()) que.pop();
vt++;
que.push(node(i, 0));
vst[i] = vt;
while(!que.empty()){
node u = que.front(); que.pop();
for(int e = adj[u.now]; e; e = nxt[e]){
int v = go[e];
if(vst[v] == vt) continue;
dist[i][v] = u.dis + 1;
vst[v] = vt;
node ret = node(v, u.dis + 1);
que.push(ret);
}
}
} inline void init(){
memset(dist, OO, sizeof dist);
for(int i = 1; i <= n; i++) dist[i][i] = 0, Bfs(i);
for(int i = 1; i <= n; i++){
P[i][i] = i;
for(int j = i + 1; j <= n; j++){
/*与i相邻的与j最近的点*/
int mndis = OO, point = 0;
for(int e = adj[i]; e; e = nxt[e]){
int v = go[e];
if(dist[v][j] < mndis){
mndis = dist[v][j];
point = v;
}
else if(dist[v][j] == mndis && v < point) point = v;
}
P[i][j] = point;
/*与j相邻的与i最近的点*/
mndis = OO, point = 0;
for(int e = adj[j]; e; e = nxt[e]){
int v = go[e];
if(dist[v][i] < mndis){
mndis = dist[v][i];
point = v;
}
else if(dist[v][i] == mndis && v < point) point = v;
}
P[j][i] = point;
}
}
} inline double F(int u, int v){
if(f[u][v] >= 0) return f[u][v];
f[u][v] = 1.0;
int to = P[P[u][v]][v];
double p = 1.0 / (1.0*deg[v] + 1.0);
f[u][v] += F(to, v) * p;
for(int e = adj[v]; e; e = nxt[e]){
int vj = go[e];
f[u][v] += F(to, vj) * p;
}
return f[u][v];
} int main(){
freopen("h.in", "r", stdin);
scanf("%d%d%d%d", &n, &m, &p, &q);
for(int i = 1; i <= m; i++){
int x, y;
scanf("%d%d", &x, &y);
addEdge(x, y), addEdge(y, x);
}
init();
for(int i = 1; i <= n; i++)
for(int j = 1; j <= n; j++)
f[i][j] = -5555;
for(int i = 1; i <= n; i++){
f[i][i] = 0;
for(int j = i + 1; j <= n; j++){
if(dist[i][j] <= 2) f[i][j] = f[j][i] = 1.0;
}
}
printf("%.3lf\n", F(p, q));
}

BZOJ1415 聪聪与可可 - 期望dp的更多相关文章

  1. 【BZOJ】1415 [Noi2005]聪聪和可可 期望DP+记忆化搜索

    [题意]给定无向图,聪聪和可可各自位于一点,可可每单位时间随机向周围走一步或停留,聪聪每单位时间追两步(先走),问追到可可的期望时间.n<=1000. [算法]期望DP+记忆化搜索 [题解]首先 ...

  2. BZOJ 1415 聪聪和可可(期望DP)

    我们可以用n次BFS预处理出 to[][]数组,to[i][j]表示聪聪从i点到j点第一步会走哪个点. 那么对于聪聪在i点,可可在j点,聪聪先走,定义dp[i][j]表示步数期望. 那么显然有dp[i ...

  3. 洛谷4206/NOI2005T4 聪聪和可可 期望DP+记忆化搜索

    题意:给出n个点m条边的无向图,两个主角聪聪和可可开始分别在S点和T点.聪聪想吃掉可可,每次由匆匆先行动后来可可行动.聪聪的行动是选他到可可的最短路上的点走最多两步(如果最短路有几条就选编号最小的走) ...

  4. bzoj 1415: [Noi2005]聪聪和可可 期望dp+记忆化搜索

    期望dp水题~ 你发现每一次肯定是贪心走 2 步,(只走一步的话就可能出现环) 然后令 $f[i][j]$ 表示聪在 $i$,可在 $j$,且聪先手两个人碰上面的期望最小次数. 用记忆化搜索转移就行了 ...

  5. luogu P4206 [NOI2005]聪聪与可可 期望dp 记忆化搜索

    LINK:聪聪与可可 这道题的核心是 想到如何统计答案. 如果设f[i][j]表示第i个时刻... 可以发现还需要统计位置信息 以及上一次到底被抓到没有的东西 不太好做. 两者的位置都在变化 所以需要 ...

  6. [NOI2005]聪聪与可可(期望dp)

    题意:给一张无向图,有一只猫和一只老鼠,猫每秒会向老鼠的方向移动两个单位,若它们的距离为一,那么只会移动一个单位,老鼠会等概率向周围移动一步或不动,求猫抓到老鼠的期望时间. Solutionluogu ...

  7. BZOJ1415 [Noi2005]聪聪和可可 【SPFA + 期望dp记忆化搜索】

    题目 输入格式 数据的第1行为两个整数N和E,以空格分隔,分别表示森林中的景点数和连接相邻景点的路的条数. 第2行包含两个整数C和M,以空格分隔,分别表示初始时聪聪和可可所在的景点的编号. 接下来E行 ...

  8. bzoj1415 [Noi2005]聪聪和可可【概率dp 数学期望】

    传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=1415 noip2016 D1T3,多么痛的领悟...看来要恶补一下与期望相关的东西了. 这是 ...

  9. 概率/期望DP初步——BZOJ1415 聪聪和可可

    期望相关: 数学期望,可以简单理解的加权平均数.设有一系列的值$x_i$,每个值被取到的概率为$p_i$,则期望$E=\sum\limits_{i=1}^n p_i x_i$. 期望具有线性性:$$E ...

随机推荐

  1. 1.2 Use Cases中 Website Activity Tracking官网剖析(博主推荐)

    不多说,直接上干货! 一切来源于官网 http://kafka.apache.org/documentation/ Website Activity Tracking 网站活动追踪 The origi ...

  2. JS如何动态生成变量名[重点]

    解决方案: function create_variable(num){           var name = "test_"+num;   //生成函数名           ...

  3. ThinkPHP5.0---方法异常格式

    public function test(){ try{ // 获取到ThinkPHP的内置异常时,直接向上抛出,交给ThinkPHP处理 }catch (\think\Exception\HttpR ...

  4. 洛谷 P1143 进制转换

    P1143 进制转换 题目描述 请你编一程序实现两种不同进制之间的数据转换. 输入输出格式 输入格式: 输入数据共有三行,第一行是一个正整数,表示需要转换的数的进制n(2≤n≤16),第二行是一个n进 ...

  5. HTTP网络协议(四)

    确保Web安全的HTTPS HTTP存在三个比较明显的缺点: 通信使用明文(不加密),内容可能会被窃听. 不验证通信方的身份,因此有可能遭遇伪装. 无法证明报文的完整性,所以可能已遭篡改.  尽管HT ...

  6. Surging 微服务框架使用入门

    原文:Surging 微服务框架使用入门 前言 本文非 Surging 官方教程,只是自己学习的总结.如有哪里不对,还望指正.  我对 surging 的看法 我目前所在的公司采用架构就是类似与Sur ...

  7. Java 学习(18):Java 序列化& 网络编程& 发送邮件

    --Java 序列化 -- 网络编程 -- 发送邮件 Java 序列化 Java 提供了一种对象序列化的机制,该机制中,一个对象可以被表示为一个字节序列,该字节序列包括该对象的数据.有关对象的类型的信 ...

  8. orabbix 报错No suitable driver found for

     orabbix报错如下:   2018-07-11 14:35:20,119 [main] ERROR Orabbix - Error on Configurator for database qa ...

  9. 使用wepy开发微信小程序商城第一篇:项目初始化

    使用wepy开发微信小程序商城 第一篇:项目初始化 前言: wepy小程序项目初始化的操作,官方文档看了好几遍,感觉写得不是很清楚. 这篇写得挺好的:小程序开发之wepy 1.初始化项目 (1)全局安 ...

  10. Java RMI使用

    1. Java RMI介绍 RMI:远程方法调用(Remote Method Invocation).能够让在某个java虚拟机上的对象像调用本地对象方法一样调用另一个java 虚拟机中的对象上的方法 ...