【CF679D】Bear and Chase

题意:近日,鼠国的头号通缉犯,神出鬼没的怪盗——Joker正于摩登市出没!对于名侦探Jack来说,这正是将其捉拿归案的大号时机。形式化地,摩登市可以看成一张 $n$ 个点,$m$ 条边的简单无向连通图。Jack有一个神奇的探测器:MC(Mouse Chaser)。当Jack在某个城市使用MC时,MC会显示Joker所在城市与Jack所在城市之间的距离(即最短路所经过的边数)。Jack只有两天的时间捉拿Joker,具体过程如下:

1.第一天,Joker随机潜伏在某个城市,即Joker位于每个城市的概率都是 $1\over n$ 。Jack将挑选一个城市 $a$ ,在 $a$ 处使用MC,得知Joker所在城市与 $a$ 的距离。然后Jack可以选择立刻调查某个城市:如果Joker正好位于被调查的城市,则Jack成功地将Joker捉拿归案(如果Joker刚好位于城市 $a$ ,那么MC会显示 $0$ ,显然Jack直接调查城市 $a$ 就能直接将Joker捉拿归案);否则,Joker会意识到自己正被追查,从而立刻逃离摩登市,导致Jack的任务直接失败!

2.如果第一天没有立刻调查。那么在夜里,Joker会随机选择一个与Joker所在城市相邻的城市,并前往该城市。即如果有 $d$ 个城市与Joker所在城市相连,则Joker有 $1\over d$ 的概率前往其中的每个城市。

3.第二天,Jack将挑选一个城市 $b$ ,在 $b$ 处使用MC(忽略Jack从 $a$ 前往 $b$ 的时间),得知Joker所在城市与 $b$ 的距离。然后Jack必须选择一个城市进行调查。如果Joker刚好位于被调查的城市,则Jack成功的将Joker捉拿归案;否则,Jack的任务失败。

现在,请你帮助Jack,制定合适的追捕计划,选择前往调查的城市,使得Jack将Joker捉拿归案的概率最大。输出这个最大的概率。

$2\le n\le 400,n-1\le m\le {n(n-1)\over 2},1\le x,y\le n$

题解:先考虑暴力的解法。我们枚举两次使用MC的城市a和b,然后用f[i][j]表示第一天显示i,第二天显示j的概率。我们得到f[i][j]后,用f数组求出g[i]表示第一天在a使用MC显示i的最大概率,进而得到在a使用MC的最大总概率。这样做的复杂度显然是$O(n^4)$的。

但是我们发现,如果我们枚举了第一天可能的位置x,则i=dis[a][x],j只能等于dis[b][x]-1,dis[b][x],dis[b][x]+1。我们可以进行一些预处理,然后复杂度就降到$O(n^3)$了。

  1. #include <cstdio>
  2. #include <cstring>
  3. #include <iostream>
  4. #include <algorithm>
  5. #include <vector>
  6. using namespace std;
  7. typedef double db;
  8. int n,m,now;
  9. int f[410][410],pa[100000],pb[100000],d0[410][410],d1[410][410],d2[410][410],d[410],vis[410][410],cnt[410];
  10. db s0[410][410],s1[410][410],s2[410][410],p[410][410],s[410];
  11. vector<int> v[410];
  12. vector<int>::iterator it;
  13. db tmp,ans;
  14. inline void upd(db &x,db y) {if(x<y) x=y;}
  15. inline void upd(int a,int b,db x)
  16. {
  17. if(a<0) return ;
  18. if(vis[a][b]!=now) vis[a][b]=now,p[a][b]=0,v[a].push_back(b);
  19. upd(p[a][b],x);
  20. }
  21. int main()
  22. {
  23. scanf("%d%d",&n,&m);
  24. memset(f,0x3f,sizeof(f));
  25. int i,j,k,a,b;
  26. for(i=1;i<=n;i++) f[i][i]=0;
  27. for(i=1;i<=m;i++) scanf("%d%d",&a,&b),pa[i]=a,pb[i]=b,d[a]++,d[b]++,f[a][b]=f[b][a]=1;
  28. for(k=1;k<=n;k++)
  29. {
  30. for(i=1;i<=n;i++) for(j=1;j<=n;j++) f[i][j]=min(f[i][j],f[i][k]+f[k][j]);
  31. }
  32. for(i=1;i<=n;i++)
  33. {
  34. for(j=1;j<=m;j++)
  35. {
  36. if(f[i][pb[j]]==f[i][pa[j]]+1) s1[i][pa[j]]+=1.0/n/d[pb[j]],s2[i][pb[j]]+=1.0/n/d[pa[j]];
  37. if(f[i][pa[j]]==f[i][pb[j]]+1) s1[i][pb[j]]+=1.0/n/d[pa[j]],s2[i][pa[j]]+=1.0/n/d[pb[j]];
  38. if(f[i][pa[j]]==f[i][pb[j]]) s0[i][pa[j]]+=1.0/n/d[pb[j]],s0[i][pb[j]]+=1.0/n/d[pa[j]];
  39. }
  40. }
  41. for(i=1;i<=n;i++)
  42. {
  43. memset(cnt,0,sizeof(cnt)),memset(s,0,sizeof(s));
  44. for(j=1;j<=n;j++) cnt[f[i][j]]++;
  45. for(j=0;j<=n;j++) if(cnt[j]) s[j]=1.0/n;
  46. for(j=1;j<=n;j++)
  47. {
  48. now++;
  49. for(k=1;k<=n;k++)
  50. {
  51. upd(f[i][k],f[j][k],s0[i][k]);
  52. upd(f[i][k]+1,f[j][k],s1[i][k]);
  53. upd(f[i][k]-1,f[j][k],s2[i][k]);
  54. }
  55. for(k=0;k<=n;k++)
  56. {
  57. tmp=0;
  58. for(it=v[k].begin();it!=v[k].end();it++) tmp+=p[k][*it];
  59. v[k].clear();
  60. upd(s[k],tmp);
  61. }
  62. }
  63. tmp=0;
  64. for(j=0;j<=n;j++) tmp+=s[j];
  65. ans=max(ans,tmp);
  66. }
  67. printf("%.12lf",ans);
  68. return 0;
  69. }//6 14 1 6 2 6 3 6 4 6 5 6 1 5 2 5 3 5 4 5 2 4 3 4 1 3 2 3 1 2

【CF679D】Bear and Chase 最短路+乱搞的更多相关文章

  1. 洛谷 P1529 回家 Bessie Come Home Label:Dijkstra最短路 && 乱搞

    题目描述 现在是晚餐时间,而母牛们在外面分散的牧场中. 农民约翰按响了电铃,所以她们开始向谷仓走去. 你的工作是要指出哪只母牛会最先到达谷仓(在给出的测试数据中,总会有且只有一只最快的母牛). 在挤奶 ...

  2. P5304 [GXOI/GZOI2019]旅行者(最短路/乱搞)

    luogu bzoj Orz自己想出神仙正解的sxy 描述略 直接把所有起点推进去跑dijkstra... 并且染色,就是记录到这个点的最短路是由哪个起点引导出来的 然后再把所有边反指跑一次... 之 ...

  3. codeforces 653C C. Bear and Up-Down(乱搞题)

    题目链接: C. Bear and Up-Down time limit per test 2 seconds memory limit per test 256 megabytes input st ...

  4. 【51nod1443】路径和树(堆优化dijkstra乱搞)

    点此看题面 大致题意:给你一个无向联通图,要求你求出这张图中从u开始的权值和最小的最短路径树的权值之和. 什么是最短路径树? 从\(u\)开始到任意点的最短路径与在原图中相比不变. 题解 既然要求最短 ...

  5. dij-spfa乱搞

    以前见过一篇另类堆优化dij的题解,然而找不到了 那位作者称它为dij-spfa(大概是这个意思,然而确实很形象 这方法比较玄学,正确性没有严格证出来,然而对拍是验证猜想的最好途径 不过也可能并不玄学 ...

  6. URAL 1827 Indigenous Wars(排序、乱搞)

    题意:给一个长度为n数组{a[i]}.有m个操作Ti,Si,Li表示找以Ti值结束,以Si值开始,长度为Li的连续子串.找到后,将区间的答案值设为1.一开始答案值全部为0.最后输出n个答案值. 好久没 ...

  7. UVA 11853 [dfs乱搞]

    /* 大连热身E题 不要低头,不要放弃,不要气馁,不要慌张 题意: 在1000×1000的格子内有很多个炮弹中心,半径给定. 为某人能否从西部边界出发,从东部边界走出. 不能输出不能,能的话输出最北边 ...

  8. Codeforces 732e [贪心][stl乱搞]

    /* 不要低头,不要放弃,不要气馁,不要慌张 题意: 给n个插座,m个电脑.每个插座都有一个电压,每个电脑都有需求电压. 每个插座可以接若干变压器,每个变压器可以使得电压变为x/2上取整. 有无限个变 ...

  9. 【BZOJ-4692】Beautiful Spacing 二分答案 + 乱搞(DP?)

    4692: Beautiful Spacing Time Limit: 15 Sec  Memory Limit: 128 MBSubmit: 46  Solved: 21[Submit][Statu ...

随机推荐

  1. 虚拟机下CentOS7开启SSH连接

    在虚拟机(Vmware Workstation)下,安装了CentOS7,现在想通过SSH工具连接虚拟机中的CentOS7 1.  首先,要确保CentOS7安装了  openssh-server,在 ...

  2. 微软BI 之SSAS 系列 - 多维数据集维度用法之三 多对多维度 Many to Many

    开篇介绍 对于维度成员和事实数据直接的关系看到更多的可能还是一对一,一对多的关系.比方在事实维度(或退化维度)中一个订单和明细号组合而成的ID,对应的就是事实表中的一条数据,这就是一对一的关系.比方说 ...

  3. Win10更新搜狗输入法后重启输入密码蓝屏

    解决办法:如果能进入安全模式,卸载搜狗输入法:不行的话(好像不行)只能重装系统:因为蓝屏后就基本开不了了!!!生气!! win10 1809 19.3月累积更新之后蓝屏:安装了搜狗输入法的win10 ...

  4. 从源码编译InfluxDB

    操作系统 : CentOS7.3.1611_x64 go语言版本:1.8.3 linux/amd64 InfluxDB版本:1.1.0 go语言安装参考: http://www.cnblogs.com ...

  5. zabbix 中文乱码的处理

    一.乱码原因 查看cpu负载,中文乱码如下 这个问题是由于zabbix的web端没有中文字库,我们最需要把中文字库加上即可 二.解决zabbix乱码方法 2.1 上传字体文件到zabbix中 找到本地 ...

  6. Jason 和 Java 对象转化示例

    1.工程 2.代码: JsonUtil.java package com.my.json; import java.util.ArrayList; import java.util.List; imp ...

  7. Mybatis 记录

    1. #{}, ${}两种传参数方式的区别 1) ${} 会将传入的参数完全拼接到sql语句中,也就是相当于一个拼接符号. 也就是,最后的处理方式就相当于 String sql = select * ...

  8. linux 磁盘空间满了,排查记录

    先贴命令:du -m --max-depth=1或du -h --max-depth=1du:用于统计linux中文件或目录所占磁盘空间的大小du参数######-m:以M为单位展示查询结果-h:以K ...

  9. Android Error:Execution failed for task ':app:compileDebugJavaWithJavac' 解决方案

    今天使用 Android Studio 构建项目的时候出现了这个错误 compileDebugJavaWithJavac 通过搜索发现造成该问题的原因有很多需要结合具体的项目进行排查 通过 Andro ...

  10. mysql索引hash索引和b-tree索引的区别

    Hash 索引结构的特殊性,其检索效率非常高,索引的检索可以一次定位,不像B-Tree 索引需要从根节点到枝节点,最后才能访问到页节点这样多次的IO访问,所以 Hash 索引的查询效率要远高于 B-T ...