luogu P4206 聪聪和可可
聪聪和可可
鸽了两天
\(dijkstra\)预处理出来两点之间的最短路径\(dis\)数组,读题发现,\(cat\)的走位很怪sb斩了,所以我们设一个\(next\)数组,\(next[i][j]\)表示\(cat\)在\(i\)位置,\(mouse\)在\(j\)位置时,\(cat\)下一步要去的位置,
设\(i\),\(j\)之间有一条边则
next[i][k]=\min(next[i][k],j)
\]
考虑答案的转移,设\(u\)为\(cat\)当前所在的位置,\(v\)为\(mouse\)当前所在的位置,\(a\)为\(cat\)走一步所到的位置,\(b\)为\(cat\)走两步所到的位置,\(to\)为\(mouse\)可到达的位置最后记得算上一开始的v,\(du\)数组为该点的出度记得加上自己,则有以下三种情况
if(a==v||b==v)\;\;return 1; \\
else\;\;dp[u][v]+=\frac{dfs\left(b,to\right)}{\left(du[v]+1\right)}
\]
最后记得算上\(mouse\)一开始所在的位置\(v\)
\]
以上求答案的过程可用\(dfs\)解决
Code:
#include<cstdio>
#include<queue>
#define MAX 1001
#define re register
#define INF 114514
namespace OMA
{
int n,e,c,m;
int dis[MAX][MAX];
int cnt=1,head[MAX];
int du[MAX],next[MAX][MAX];
double dp[MAX][MAX];
bool pre[MAX],vis[MAX][MAX];
struct node
{
int next;
int to;
}edge[MAX<<1];
typedef std::pair<int,int>oma;
std::priority_queue<oma,std::vector<oma>,std::greater<oma> >q;
inline int read()
{
int s=0,w=1; char ch=getchar();
while(ch<'0'||ch>'9'){ if(ch=='-')w=-1; ch=getchar(); }
while(ch>='0'&&ch<='9'){ s=s*10+ch-'0'; ch=getchar(); }
return s*w;
}
inline void add(int u,int v)
{
edge[++cnt].next = head[u];
edge[cnt].to = v;
head[u] = cnt;
}
inline int min(int a,int b)
{ return a<b?a:b; }
void in()
{
n=read(),e=read(),c=read(),m=read();
for(re int i=1; i<=e; i++)
{
int u=read(),v=read();
add(u,v),add(v,u);
du[u]++,du[v]++;
}
for(re int i=1; i<=n; i++)
{
for(re int j=1; j<=n; j++)
{ next[i][j] = INF; }
}
}
inline void dijkstra(int u)
{
for(re int i=1; i<=n; i++)
{ dis[u][i] = INF ,pre[i] = false; }
while(!q.empty())
{ q.pop(); }
dis[u][u] = 0;
q.push(std::make_pair(0,u));
while(!q.empty())
{
int k = q.top().second;
q.pop();
if(pre[k])
{ continue; }
pre[k] = true;
for(re int i=head[k]; i; i=edge[i].next)
{
int to = edge[i].to;
if(!pre[to]&&(dis[u][to]>dis[u][k]+1))
{
dis[u][to] = dis[u][k]+1;
q.push(std::make_pair(dis[u][to],to));
}
}
}
}
inline double dfs(int cat,int mouse)
{
if(vis[cat][mouse])
{ return dp[cat][mouse]; }
if(cat==mouse)
{ return 0; }
int a,b;
a = next[cat][mouse];
b = next[a][mouse];
if(a==mouse||b==mouse)
{ return 1; }
dp[cat][mouse] = 1;
for(re int i=head[mouse]; i; i=edge[i].next)
{
int to = edge[i].to;
dp[cat][mouse] += dfs(b,to)/(du[mouse]+1);
}
dp[cat][mouse] += dfs(b,mouse)/(du[mouse]+1);
vis[cat][mouse] = 1;
return dp[cat][mouse];
}
signed main()
{
in();
for(re int i=1; i<=n; i++)
{ dijkstra(i); }
for(re int i=1; i<=n; i++)
{
for(re int j=head[i]; j; j=edge[j].next)
{
int to = edge[j].to;
for(re int k=1; k<=n; k++)
{
if(dis[i][k]-1==dis[k][to])
{ next[i][k] = min(next[i][k],to); }
}
}
}
printf("%.3lf\n",dfs(c,m));
return 0;
}
}
signed main()
{ return OMA::main(); }
luogu P4206 聪聪和可可的更多相关文章
- luogu P4206 [NOI2005]聪聪与可可 期望dp 记忆化搜索
LINK:聪聪与可可 这道题的核心是 想到如何统计答案. 如果设f[i][j]表示第i个时刻... 可以发现还需要统计位置信息 以及上一次到底被抓到没有的东西 不太好做. 两者的位置都在变化 所以需要 ...
- P4206[NOI2005]聪聪与可可
链接P4206 [NOI2005]聪聪与可可 类似于开车旅行,如果老鼠确定了那么猫的路线是确定的. 预处理\(g_{i,j}\)表示老鼠在\(i\)号点,猫的下一步方向,\(Bfs\)就行了 设\(f ...
- Luogu 4206 [NOI2005]聪聪与可可
BZOJ 1415 简单期望 + 记忆化搜索. 发现聪聪每一步走向的地方是在可可的所在位置确定时是确定的,设$nxt_{x, y}$表示聪聪在$x$,可可在$y$时聪聪下一步会走到哪里,我们先预处理出 ...
- [luogu 2634]聪聪可可
题目描述 聪聪和可可是兄弟俩,他们俩经常为了一些琐事打起来,例如家中只剩下最后一根冰棍而两人都想吃.两个人都想玩儿电脑(可是他们家只有一台电脑)……遇到这种问题,一般情况下石头剪刀布就好了,可是他们已 ...
- luogu P2634 [国家集训队]聪聪可可 点分治
Description 聪聪和可可是兄弟俩,他们俩经常为了一些琐事打起来,例如家中只剩下最后一根冰棍而两人都想吃.两个人都想玩儿电脑(可是他们家只有一台电脑)……遇到这种问题,一般情况下石头剪刀布就好 ...
- 洛谷 P4206 [NOI2005]聪聪与可可 题解
题面 输入 数据的第1行为两个整数N和E,以空格分隔,分别表示森林中的景点数和连接相邻景点的路的条数. 第2行包含两个整数C和M,以空格分隔,分别表示初始时聪聪和可可所在的景点的编号. 接下来E行,每 ...
- 【P2634】聪聪可可——点分治
(题面来自Luogu) 题目描述 聪聪和可可是兄弟俩,他们俩经常为了一些琐事打起来,例如家中只剩下最后一根冰棍而两人都想吃.两个人都想玩儿电脑(可是他们家只有一台电脑)--遇到这种问题,一般情况下石头 ...
- [bzoj2152][聪聪和可可] (点分治+概率)
Description 聪聪和可可是兄弟俩,他们俩经常为了一些琐事打起来,例如家中只剩下最后一根冰棍而两人都想吃.两个人都想玩儿电脑(可是他们家只有一台电脑)……遇到这种问题,一般情况下石头剪刀布就好 ...
- BZOJ 1415 【NOI2005】 聪聪和可可
题目链接:聪聪和可可 一道水题--开始还看错题了,以为边带权--强行\(O(n^3)\)预处理-- 首先,我们显然可以预处理出一个数组\(p[u][v]\)表示可可在点\(u\),聪聪在点\(v\)的 ...
随机推荐
- 小程序textarea设置maxlength后不是你想的那样简单
可能很多小伙伴们.看见这个标题后; 觉得作者是一个标题党. textarea设置maxlength后, 限制用户输入的字符呗! 还能怎么样呢? 恭喜你,说对了一半. 之前我也一直是这样想的. 知道今天 ...
- SQL关联子查询
SQL关联子查询执行顺序: 1.先取到主查询中的相关数据,一次取一行主查询的数据 2.然后传入子查询,进行子查询 3.最后做主查询where筛选,注意子查询的where条件同样需要加在主查询后 参考: ...
- FastTunnel-内网穿透原理揭秘
之前写了一篇关于GVP开源项目FastTunnel的一篇介绍 <FastTunnel-开源内网穿透框架>,只简单介绍了使用方法,不少伙伴对其原理表示好奇,今天画抽空了一下其内部实现原理流程 ...
- ArchLinux安装步骤(一)
本文为安装archlinux的教程,需要有硬盘分区,挂载等基础linux命令的了解还有vim的基本操作,不知道也没关系,这里有大神的视频教程ArchLinux指南. 确实是不是uefi模式 ls /s ...
- Spring Boot(三):Spring Boot中的事件的使用 与Spring Boot启动流程(Event 事件 和 Listeners监听器)
前言:在讲述内容之前 希望大家对设计模式有所了解 即使你学会了本片的内容 也不知道什么时候去使用 或者为什么要这样去用 观察者模式: 观察者模式是一种对象行为模式.它定义对象间的一种一对多的依赖关系, ...
- 【LeetCode】54. 螺旋矩阵
54. 螺旋矩阵 知识点:数组: 题目描述 给你一个 m 行 n 列的矩阵 matrix ,请按照 顺时针螺旋顺序 ,返回矩阵中的所有元素. 示例 输入:matrix = [[1,2,3],[4,5, ...
- Javascript闭包解析----------------v客学院技术分享
跟java,php等编程语言一样,javascript也采用词法作用域,简单的来说就是函数的执行依赖于变量的作用域,这个作用域是在函数定义时决定的,而不是函数调用时决定的.为了实现这种词法作用域,还必 ...
- PAT乙级:1069 微博转发抽奖 (20分)
PAT乙级:1069 微博转发抽奖 (20分) 题干 小明 PAT 考了满分,高兴之余决定发起微博转发抽奖活动,从转发的网友中按顺序每隔 N 个人就发出一个红包.请你编写程序帮助他确定中奖名单. 输入 ...
- Python在ubuntu16.04上环境搭建
1.anaconda3安装 mkdir anaconda cd anaconda wget https://repo.continuum.io/archive/Anaconda3-4.4.0-Linu ...
- NOIp 2020
游记 Day-1 我已经开始慌了. 不知道前路如何.不想回文化课.唯一一次机会,可是这几天却一直在颓,不颓就慌. 没心思写题,导致这几天看的题啥都不会.不知道考试当天又会出什么幺蛾子. 啊啊啊,烦. ...