码迷,mamicode.com
首页 > 其他好文 > 详细

hdu4405Aeroplane chess 概率dp水题

时间:2015-07-20 19:27:20      阅读:104      评论:0      收藏:0      [点我收藏+]

标签:

//从0到n有n+1个格子
//对于格子i,掷一次骰子的数为x,那么可以从位置i到位置i+x
//格子之间有连线,如果格子a和b有连线,那么从a到b不用掷骰子
//求从0到n的骰子掷的次数的期望
//dp[i] = 1/6*segma(dp[k]) + 1 (i<=k<=i+6)
#include<cstdio>
#include<iostream>
#include<cstring>
using namespace std ;
const int maxn = 100000 ;
double dp[maxn] ;
int line[maxn] ;
int main()
{
    int n , m ;
    while(scanf("%d%d" , &n  ,&m) && n+m)
    {
        memset(line , -1 , sizeof(line)) ;
        memset(dp , 0 ,sizeof(dp)) ;
        int a , b ;
        for(int i = 1;i <= m ;i++)
        {
            scanf("%d%d" ,&a , &b) ;
            line[a] = b ;
        }
        for(int i = n-1 ;i >= 0 ;i--)
        {
            if(line[i] != -1){dp[i] = dp[line[i]] ;continue;}
            for(int k = i + 1;k <= i+6 ;k++)
            dp[i] += ((double)1/(double)6)*dp[k];
            dp[i] += 1 ;
        }
        printf("%.4lf\n" , dp[0]) ;
    }
    return 0 ;
}

版权声明:本文为博主原创文章,未经博主允许不得转载。

hdu4405Aeroplane chess 概率dp水题

标签:

原文地址:http://blog.csdn.net/cq_pf/article/details/46972431

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!