bzoj 1415: [Noi2005]聪聪和可可【期望dp+bfs】

因为边权为1所以a直接bfs瞎搞就行……我一开始竟然写了个spfa

#include<iostream>
#include<cstdio>
#include<queue>
#include<cstring>
using namespace std;
const int N=1005,inf=1e9;
int n,m,st,ed,h[N],cnt,a[N][N],b[N][N],dis[N][N],d[N];
double f[N][N];
bool v[N][N];
struct qwe
{
    int ne,to;
}e[N<<1];
int read()
{
    int r=0,f=1;
    char p=getchar();
    while(p>‘9‘||p<‘0‘)
    {
        if(p==‘-‘)
            f=-1;
        p=getchar();
    }
    while(p>=‘0‘&&p<=‘9‘)
    {
        r=r*10+p-48;
        p=getchar();
    }
    return r*f;
}
void add(int u,int v)
{
    cnt++;
    e[cnt].ne=h[u];
    e[cnt].to=v;
    h[u]=cnt;
}
double dfs(int u,int v)
{
    if(f[u][v]>=-1)
        return f[u][v];
    if(u==v)
        return f[u][v]=0;
    if(dis[u][v]<=2)
        return f[u][v]=1;
    double p=1.0/((double)d[v]+1.0);
    f[u][v]=1;
    for(int i=h[v];i;i=e[i].ne)
        f[u][v]+=p*dfs(a[u][v],e[i].to);
    f[u][v]+=p*dfs(a[u][v],v);
    return f[u][v];
}
int main()
{
    n=read(),m=read(),st=read(),ed=read();
    for(int i=1;i<=m;i++)
    {
        int x=read(),y=read();
        d[x]++,d[y]++;
        add(x,y),add(y,x);
    }
    queue<int>q;
    for(int s=1;s<=n;s++)
    {
        v[s][s]=1;
        q.push(s);
        while(!q.empty())
        {
            int u=q.front();
            q.pop();
            for(int i=h[u];i;i=e[i].ne)
                if(!v[s][e[i].to])
                {
                    dis[s][e[i].to]=dis[s][u]+1;
                    v[s][e[i].to]=1;
                    q.push(e[i].to);
                }
        }
    }
    for(int s=1;s<=n;s++)
        for(int u=1;u<=n;u++)
        {
            int mn=inf,w=inf;
            for(int i=h[s];i;i=e[i].ne)
                if(dis[e[i].to][u]<mn||(dis[e[i].to][u]==mn&&e[i].to<w))
                    mn=dis[e[i].to][u],w=e[i].to;
            b[s][u]=w;
        }
    for(int s=1;s<=n;s++)
        for(int i=1;i<=n;i++)
            a[s][i]=dis[s][i]<=2?i:b[b[s][i]][i];
    // for(int i=1;i<=n;i++)
    // {
        // for(int j=1;j<=n;j++)
            // cerr<<a[i][j]<<" ";
        // cerr<<endl;
    // }
    memset(f,-1,sizeof(f));
    printf("%.3f\n",dfs(st,ed));
    return 0;
}

原文地址:https://www.cnblogs.com/lokiii/p/9688666.html

时间: 2024-11-05 19:30:56

bzoj 1415: [Noi2005]聪聪和可可【期望dp+bfs】的相关文章

BZOJ 1415 NOI2005 聪聪和可可 期望DP+记忆化搜索 BZOJ200题达成&amp;&amp;NOI2005全AC达成

题目大意:给定一个无向图,聪聪在起点,可可在终点,每个时刻聪聪会沿最短路走向可可两步(如果有多条最短路走编号最小的点),然后可可会等概率向周围走或不动,求平均多少个时刻后聪聪和可可相遇 今天早上起床发现194了然后就各种刷--当我发现199的时候我决定把第200题交给05年NOI仅剩的一道题--结果尼玛调了能有一个小时--我居然没看到编号最小这个限制0.0 首先我们知道,由于聪聪走两步而可可走一步,所以聪聪一定能在有限的时刻追上可可,而且两人的距离随着时间进行单调递减 于是我们记忆化搜索 首先用

bzoj 1415 [Noi2005]聪聪和可可——其实无环的图上概率

题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1415 乍一看和"游走"一样.于是高斯消元.n^2状态,复杂度n^6-- 看看TJ,发现因为聪聪不是随便走的,所以聪聪一直逼近可可.故其实无环.可以记搜. (1A还是不错的) #include<iostream> #include<cstdio> #include<cstring> #include<queue> using name

BZOJ 1415: [Noi2005]聪聪和可可 [DP 概率]

传送门 题意:小兔子乖乖~~~ 题意·真:无向图吗,聪抓可,每个时间聪先走可后走,聪一次可以走两步,朝着里可最近且点编号最小的方向:可一次只一步,等概率走向相邻的点或不走 求聪抓住可的期望时间 和游走很像,只不过这道题限制了一个人走的方向,两人间的距离具有了阶段性!可以直接$DP$ 求期望一般倒推 $f[i][j]$表示聪在$i$可在$j$抓住的期望时间 $bfs$预处理$g[i][j]$表示聪在$i$可在$j$下一步聪走到哪里 这样聪的行动就知道了,转移枚举可的行动就行啦 边界:$f[i][i

【BZOJ】4872: [Shoi2017]分手是祝愿 期望DP

[题意]给定n盏灯的01状态,操作第 i 盏灯会将所有编号为 i 的约数的灯取反.每次随机操作一盏灯直至当前状态能够在k步内全灭为止(然后直接灭),求期望步数.n,k<=10^5. [算法]期望DP [题解]对于当前状态,编号最大的亮灯必须通过操作自身灭掉. 证明:假设通过操作编号更大的灯灭掉,那么编号更大的灯只能通过操作自己灭掉,则与原来状态无区别,得证. 运用这个结论,每次灭掉最大编号的灯后的局面中,编号最大的灯一定严格小于原最大灯,所以至多需要n次操作. 从大到小,处理出m盏待操作灯,这样

bzoj 1415: [Noi2005]聪聪和可可

直接上记忆化搜索 #include<queue> #include<cstdio> #include<algorithm> using namespace std; int read_p,read_ca; inline int read(){ read_p=0;read_ca=getchar(); while(read_ca<'0'||read_ca>'9') read_ca=getchar(); while(read_ca>='0'&&

BZOJ 1778 Usaco2010 Hol Dotp 驱逐猪猡 期望DP+高斯消元

题目大意:给定一个无向图,炸弹从1号节点出发,每个时刻有P/Q的概率爆炸,如果某个时刻没有爆炸,就会等概率沿着随机一条出边走到下一个城市,求最终每个城市的爆炸概率 #include <cmath> #include <cstdio> #include <cstring> #include <iostream> #include <algorithm> #define M 330 using namespace std; int n,m,p,q;

bzoj 3029 守卫者的挑战——概率期望dp+状态数思考

题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3029 先随便写了个dfs,记录"前 i 次.成功 j 次.容量-残片=k"的概率.因为是否可行只和"成功次数"还有"容量-残片个数"有关,和容量.残片具体数量无关.准备记忆化,但发现状态存不下. #include<iostream> #include<cstdio> #include<cstring> #

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

1415: [Noi2005]聪聪和可可 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 1640  Solved: 962 Description Input 数据的第1行为两个整数N和E,以空格分隔,分别表示森林中的景点数和连接相邻景点的路的条数. 第2行包含两个整数C和M,以空格分隔,分别表示初始时聪聪和可可所在的景点的编号. 接下来E行,每行两个整数,第i+2行的两个整数Ai和Bi表示景点Ai和景点Bi之间有一条路. 所有的路都是无向的,即

【BZOJ】【1415】【NOI2005】聪聪和可可

数学期望+记忆化搜索 论文:<浅析竞赛中一类数学期望问题的解决方法>——汤可因  中的第一题…… Orz 黄学长 我实在是太弱,这么简单都yy不出来…… 宽搜预处理有点spfa的感觉= =凡是更新了的,都要重新入队更新一遍…… dp的记忆化搜索过程好厉害…… 期望这里一直很虚啊,赶紧再多做点题熟悉熟悉…… 1 /************************************************************** 2 Problem: 1415 3 User: Tunix