传送门

题目大意:

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

题目分析:

期望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. amaze样例页面分析(一)

    amaze样例页面分析(一) 一.总结 1.从审查(inspect)中是很清楚的可以弄清楚这些part之间的结构关系的 2.一者在于弄清楚他们之间的结构关系,二者在于知道结构的每一部分是干嘛的 3.i ...

  2. 10.Maven依赖排除 禁止依赖传递 取消依赖的方法

    转自:https://www.cnblogs.com/duanxz/p/6084494.html 大家都知道Maven的优点是依赖管理,特别是前期使用ANT的开发者都有很多感触.最近要开发一个java ...

  3. 右键菜单添加Total Commander

    Windows Registry Editor Version 5.00 [HKEY_CLASSES_ROOT\Folder\shell\OpeninTC]@="使用TotalCmd打开(& ...

  4. vue实现一个会员卡的组件(可以动态传入图片(分出的一个组件)、背景、文字、卡号等)

    自己在写这个组件的时候主要遇到的问题就是在动态传入背景图片或者背景色的时候没能立马顺利写出来,不过现在实现了这个简单组件就和大家分享一下 <template> <div class= ...

  5. NYOJ448_寻找最大数【贪心】

    寻找最大数 时间限制:1000 ms  |  内存限制:65535 KB 难度:2 描写叙述 请在整数 n 中删除m个数字, 使得余下的数字按原次序组成的新数最大, 比方当n=920813467185 ...

  6. Day1:第一个python小程序

    Day1:第一个python小程序与开发工具Pycharm 一.Hello World C:\Users\wenxh>python Python 3.6.2 (v3.6.2:5fd33b5, J ...

  7. 关于fatfs生成的wav文件是空,大小是0的问题

    绝大多数是因为打开错误 调试的时候,编写程序的时候 要记得res=f_open() 要有返回值res的设置

  8. HDU 1425 sort hash+加速输入

    http://acm.hdu.edu.cn/showproblem.php?pid=1425 题目大意: 给你n个整数,请按从大到小的顺序输出其中前m大的数. 其中n和m都是位于[-500000,50 ...

  9. 对象模型图(OMD)阅读指南

    樱木 原文 对象模型图(OMD)阅读指南(转载) 补充几个名词概念: UML:Unified Modeling Language 统一建模语言,是用来对软件密集系统进行可视化建模的一种语言.UML为面 ...

  10. LeetCode——Set Matrix Zeroes

    Given a m x n matrix, if an element is 0, set its entire row and column to 0. Do it in place. 原题链接:h ...