简单题,结果因为理解错题意懵逼了好久……

moveTo[x][y]表示聪聪在节点x,可可在节点y时,聪聪下一步应到达哪一个节点

dp[x][y]表示聪聪在节点x,可可在节点y,且轮到可可行动时,所需时间的数学期望(可可第一次行动不计入其内)

 #include <cstdio>
 #include <cstring>
 #include <algorithm>
 #include <vector>
 #include <queue>

 typedef std::vector<int> Vec;
 typedef Vec::iterator It;

 ;
 const double notVis=-1.0;

 Vec adj[maxN];
 int N,E;
 int C,K;
 int moveTo[maxN][maxN];

 void init()
 {
     ;i<maxN;i++) adj[i].clear();
     memset(moveTo,,sizeof(moveTo));
 }

 bool input()
 {
     if(scanf("%d%d",&N,&E)==EOF) return false;
     init();
     scanf("%d%d",&C,&K);
     int v1,v2;
     ;i<=E;i++)
     {
         scanf("%d%d",&v1,&v2);
         adj[v1].push_back(v2);
         adj[v2].push_back(v1);
     }
     return true;
 }

 struct Node
 {
     int idx;
     int layer;
     Node(int i,int l):idx(i),layer(l) {}
     bool operator < (const Node& other) const
     {
         return this->layer > other.layer ||
             (this->layer == other.layer && this->idx > other.idx);
     }
 };

 void calcMoveTo()
 {
     std::priority_queue<Node> pq;
     ;t<=N;t++)
     {
         moveTo[t][t]=t;
         pq.push(Node(t,));
         while(!pq.empty())
         {
             Node cur=pq.top();
             pq.pop();
             int& v=cur.idx;
             for(It x=adj[v].begin();x!=adj[v].end();++x)
                 if(!moveTo[*x][t])
                 {
                     moveTo[*x][t]=v;
                     pq.push(Node(*x,cur.layer+));
                 }
         }
     }
 }

 double dp[maxN][maxN];

 double solve_aux(int Cpos,int Kpos)
 {
     if(dp[Cpos][Kpos]!=0.0)
         return dp[Cpos][Kpos];
     for(It x=adj[Kpos].begin();x!=adj[Kpos].end();++x)
     {
         if(Cpos==(*x)) continue;
         int Cnext=Cpos; bool ok=false;
         ;i<= && !ok;i++)
         {
             Cnext=moveTo[Cnext][*x];
             if(Cnext==(*x))
             {
                 dp[Cpos][Kpos]+=1.0;
                 ok=true;
             }
         }
         if(!ok) dp[Cpos][Kpos]+=(1.0+solve_aux(Cnext,*x));
     }
     dp[Cpos][Kpos]/=double(adj[Kpos].size());
     return dp[Cpos][Kpos];
 }

 double solve()
 {
     if(C==K) return 0.0;
     ;i<=;i++)
     {
         C=moveTo[C][K];
         if(C==K) return 1.0;
     }
     memset(dp,,sizeof(dp));
     ;i<=N;i++) adj[i].push_back(i);
     return 1.0+solve_aux(C,K);
 }

 int main()
 {
     while(input())
     {
         calcMoveTo();
         printf("%.3lf\n",solve());
     }
     ;
 }

Vijos1675 NOI2005 聪聪和可可 记忆化搜索的更多相关文章

  1. BZOJ1415[Noi2005]聪聪和可可——记忆化搜索+期望dp

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

  2. BZOJ 1415: [Noi2005]聪聪和可可(记忆化搜索+期望)

    传送门 解题思路 还是比较简答的一道题.首先\(bfs\)把每个点到其他点的最短路求出来,然后再记忆化搜索.记搜的时候猫的走法是确定的,搜一下老鼠走法就行了. 代码 #include<iostr ...

  3. 【NOI2005】聪聪和可可 概率与期望 记忆化搜索

    1415: [Noi2005]聪聪和可可 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 1635  Solved: 958[Submit][Statu ...

  4. 【BZOJ 1415】 1415: [Noi2005]聪聪和可可 (bfs+记忆化搜索+期望)

    1415: [Noi2005]聪聪和可可 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 1640  Solved: 962 Description I ...

  5. 【BZOJ】1415: [Noi2005]聪聪和可可【期望】【最短路】【记忆化搜索】

    1415: [Noi2005]聪聪和可可 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 2335  Solved: 1373[Submit][Stat ...

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

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

  7. 【bzoj1415】[Noi2005]聪聪和可可 期望记忆化搜索

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

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

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

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

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

随机推荐

  1. 【转】VC的MFC中重绘函数的使用总结(整理)

    原文网址:http://www.cnblogs.com/x8023z/archive/2008/12/09/mfc33.html 在刷新窗口时经常要调用重绘函数MFC提供了三个函数用于窗口重绘Inva ...

  2. Android学习笔记(七)两个Fragment简单跳转示例

    在前两篇博文中分别介绍了Fragment得基础和Fragment的生命周期,然而说了这么多Fragment到底怎么用呢以及我们为什么要使用Fragment?本篇博文将主要探讨这两个问题,首先说下在AP ...

  3. Scrambled Polygon - POJ 2007(求凸包)

    给一些点,这些点都是一个凸包上的顶点,以第一个点为起点顺时针把别的点拍排一下序列. 分析:最简单的极坐标排序了..................... 代码如下: ----------------- ...

  4. wmic

    前沿:WMIC命令在我们的工作中可以帮助我们减少对其他工具的依赖并节省我们的时间,实在是一个值得学习和研究的好东西 命令很多,这里我把网上目前能找到的较实用的一些命令整理出来,希望各位看官能找到自己需 ...

  5. zy 送画

    问题描述 话说在军训的倒数第二天,zy终于下定决心要将画了 10天之久的画像送给他心怡的法学院mm.但是,他不敢自己一个人去,倒霉的 kk 只能和他一起去了.不过,为了表现的有诚意,kk和zy不能走在 ...

  6. 获取windows系统信息

    在应用程序中,有时需要在界面中显示计算机的硬件信息和进程信息.在.Net中提供了可以查询信息的类.Management类,在程序中添加应用后进行使用. 1 属性 类似的属性介绍可见下面: 属性介绍 根 ...

  7. 【Android - MD】之TextInputLayout的使用

    TextInputLayout是Android 5.0新特性--Material Design中的一个布局控件,主要用来嵌套EditText,实现数据输入时的一些效果,如: 当输入框获取焦点时,输入提 ...

  8. 关于无光盘无u盘状态下该如何安装系统

    看到好东西,跟大家分享一下,需要装系统的可以作为参考资料 无光盘无u盘状态下该如何安装系统 重点  : 安装虚拟光驱(用来打开镜像文件) 一个你要安装的系统文件的iso镜像文件 http://www. ...

  9. 异常Address already in use: JVM_Bind的处理

    如题,Address already in use: JVM_Bind这个异常的意思就是说jvm被占用了 那么大家一般的解决情况都是重启一下eclipse , 结果还是不行,结果就只能重启电脑了. 对 ...

  10. android 24 设置与桌面相同的action和category

    设置与桌面相同的action和category 安卓系统桌面也是一个activity,安卓桌面的action和category是: <activity android:name="co ...