首页 > 其他 > 详细

HDU 5001-Walk(概率dp)

时间:2015-08-17 23:24:30      阅读:229      评论:0      收藏:0      [点我收藏+]

题意:

给你一个图,求在长度为d的所有路径,不经过每个结点的概率

分析:

枚举每个结点,正推求概率

#include <map>
#include <set>
#include <list>
#include <cmath>
#include <queue>
#include <stack>
#include <cstdio>
#include <vector>
#include <string>
#include <cctype>
#include <complex>
#include <cassert>
#include <utility>
#include <cstring>
#include <cstdlib>
#include <iostream>
#include <algorithm>
using namespace std;
typedef pair<int,int> PII;
typedef long long ll;
#define lson l,m,rt<<1
#define pi acos(-1.0)
#define rson m+1,r,rt<<11
#define All 1,N,1
#define read freopen("in.txt", "r", stdin)
const ll  INFll = 0x3f3f3f3f3f3f3f3fLL;
const int INF= 0x7ffffff;
const int mod =  1000000007;
vector<int>e[55];
int n,m,d;
double dp[55][10010];
void solve(){
    for(int i=1;i<=n;++i){
        memset(dp,0,sizeof(dp));
        for(int p=1;p<=n;++p)
            dp[p][0]=1.0/n;
        for(int j=0;j<d;++j){
            for(int k=1;k<=n;++k){
                if(k==i)continue;
                for(int l=0;l<e[k].size();++l){
                    if(e[k][l]==i)continue;
                    dp[e[k][l]][j+1]+=dp[k][j]*1.0/e[k].size();
                }
            }
        }
        double total=0.0;
        for(int j=1;j<=n;++j)
            if(j!=i)
            total+=dp[j][d];
        printf("%.10lf\n",total);
    }
}
int main()
{
    int t;
    scanf("%d",&t);
    while(t--){
        scanf("%d%d%d",&n,&m,&d);
        int u,v;
        for(int i=1;i<=n;++i)
            e[i].clear();
        while(m--){
            scanf("%d%d",&u,&v);
            e[u].push_back(v);
            e[v].push_back(u);
        }
        solve();
    }
return 0;
}

 

HDU 5001-Walk(概率dp)

原文:http://www.cnblogs.com/zsf123/p/4737908.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!