BZOJ1415 聪聪与可可 - 期望dp
题目大意:
一张无向图上有一只猫和一只老鼠,猫先走,鼠后走。猫每次会向与其相邻的并且距离老鼠最近的点移动(若距离相等去编号较小的),如果移动一步后还没吃到老鼠,还可以再移动一步(算在一个时间内的)。老鼠每次会向相邻的点移动或者不移动,所有选择的概率相同。问猫期望多少时间能够吃到老鼠。
题目分析:
期望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$$
方程上面两式分别对应:
- 猫移动,鼠不移动。
- 猫移动,鼠移动。
初始化:$$f[i][i] = 0$$
\]
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的更多相关文章
- 【BZOJ】1415 [Noi2005]聪聪和可可 期望DP+记忆化搜索
[题意]给定无向图,聪聪和可可各自位于一点,可可每单位时间随机向周围走一步或停留,聪聪每单位时间追两步(先走),问追到可可的期望时间.n<=1000. [算法]期望DP+记忆化搜索 [题解]首先 ...
- BZOJ 1415 聪聪和可可(期望DP)
我们可以用n次BFS预处理出 to[][]数组,to[i][j]表示聪聪从i点到j点第一步会走哪个点. 那么对于聪聪在i点,可可在j点,聪聪先走,定义dp[i][j]表示步数期望. 那么显然有dp[i ...
- 洛谷4206/NOI2005T4 聪聪和可可 期望DP+记忆化搜索
题意:给出n个点m条边的无向图,两个主角聪聪和可可开始分别在S点和T点.聪聪想吃掉可可,每次由匆匆先行动后来可可行动.聪聪的行动是选他到可可的最短路上的点走最多两步(如果最短路有几条就选编号最小的走) ...
- bzoj 1415: [Noi2005]聪聪和可可 期望dp+记忆化搜索
期望dp水题~ 你发现每一次肯定是贪心走 2 步,(只走一步的话就可能出现环) 然后令 $f[i][j]$ 表示聪在 $i$,可在 $j$,且聪先手两个人碰上面的期望最小次数. 用记忆化搜索转移就行了 ...
- luogu P4206 [NOI2005]聪聪与可可 期望dp 记忆化搜索
LINK:聪聪与可可 这道题的核心是 想到如何统计答案. 如果设f[i][j]表示第i个时刻... 可以发现还需要统计位置信息 以及上一次到底被抓到没有的东西 不太好做. 两者的位置都在变化 所以需要 ...
- [NOI2005]聪聪与可可(期望dp)
题意:给一张无向图,有一只猫和一只老鼠,猫每秒会向老鼠的方向移动两个单位,若它们的距离为一,那么只会移动一个单位,老鼠会等概率向周围移动一步或不动,求猫抓到老鼠的期望时间. Solutionluogu ...
- BZOJ1415 [Noi2005]聪聪和可可 【SPFA + 期望dp记忆化搜索】
题目 输入格式 数据的第1行为两个整数N和E,以空格分隔,分别表示森林中的景点数和连接相邻景点的路的条数. 第2行包含两个整数C和M,以空格分隔,分别表示初始时聪聪和可可所在的景点的编号. 接下来E行 ...
- bzoj1415 [Noi2005]聪聪和可可【概率dp 数学期望】
传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=1415 noip2016 D1T3,多么痛的领悟...看来要恶补一下与期望相关的东西了. 这是 ...
- 概率/期望DP初步——BZOJ1415 聪聪和可可
期望相关: 数学期望,可以简单理解的加权平均数.设有一系列的值$x_i$,每个值被取到的概率为$p_i$,则期望$E=\sum\limits_{i=1}^n p_i x_i$. 期望具有线性性:$$E ...
随机推荐
- mmx-编译脚本
脚本目录位置 /home/zhangshuli/git2/vanzo_team/xulei/Mmx.py 在-/bin目录下,链接Mmx.py ln -sf ~/git2/vanzo_team/xul ...
- ontouch-控件添加ontouch监听事件
1,代码public class CalculatorViewPager extends ViewPager {}中 package com.android.calculator2; import a ...
- 12. ZooKeeper之Java客户端API使用—创建会话。
转自:https://blog.csdn.net/en_joker/article/details/78686649 客户端可以通过创建一个ZooKeeper(org.apache.zookeeper ...
- Windows 7 下快速挂载和分离VHD文件的小脚本
1.保存以下代码为VDM.vbs,放在Windows\system32下 Dim ArgsSet Args = WScript.ArgumentsTranArgs = " "For ...
- Java基础学习总结(28)——Java对各种排序算法的实现
这里总结下各种排序算法的java实现 冒泡排序 public class BubbleSort { publicstaticint[] bubbleSort(int[] array) { if(arr ...
- MongoDbHelper 帮助类(下)
对MongoDbHelper帮助类进行了一下整合,但是代码中一个方法需要将string类型转化为BsonValue类型一直出错.所以欢迎留言指正 using System; using System. ...
- UVA 11388 - GCD LCM 水~
看题传送门 题目大意: 输入两个数G,L找出两个正整数a 和b,使得二者的最大公约数为G,最小公倍数为L,如果有多解,输出a<=b且a最小的解,无解则输出-1 思路: 方法一: 显然有G< ...
- 程序猿必备软件转载自 www.uhdesk.com
XMLSpy 2012 企业版中文破解版 软件描写叙述: XMLSpy是XML(标准通用标记语言的子集)编辑器,支持WYSWYG.支持Unicode.多字符集,支持Well-formed和Valida ...
- 结合Wireshark捕获分组深入理解TCP/IP协议栈之TCP协议(TCP报文格式+三次握手实例)
摘要: 本文简单介绍了TCP面向连接理论知识,详细讲述了TCP报文各个字段含义,并从Wireshark俘获分组中选取TCP连接建立相关报文段进行分析. 一.概述 TCP是面向连接的可靠 ...
- chrome-extensions -- copytables. verygood
https://www.crx4chrome.com/extensions/ekdpkppgmlalfkphpibadldikjimijon/,通过设置快捷键,一般是拷贝多行