题意:沿着x轴从0走到大于等于N的某处,每一步的步数由骰子(1,2,3,4,5,6)决定,若恰好走到x轴上某飞行路线的起点,则不计入扔骰子数。问从0走到大于等于N的某处的期望的扔骰子次数。

分析:

1、dp[i]表示从位置i到终点期望的扔骰子次数。

2、很显然倒着往前推,因为从起点0开始,扔骰子的次数有很多种可能,难以计算,但是dp[N]很显然是0,不需要扔骰子即可到达终点。

3、假设当前位于位置i,根据骰子数可能到达的位置有i + j(j=1,2,3,4,5,6),到达其中每个位置的概率都是1/6,

与此同时继承了从所到达的位置到终点的所需扔的骰子数,即dp[i] += dp[i + j] / 6。

4、而从位置i到位置i+j是需要扔一次骰子的,所以 ++dp[i]。

#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<cctype>
#include<cmath>
#include<iostream>
#include<sstream>
#include<iterator>
#include<algorithm>
#include<string>
#include<vector>
#include<set>
#include<map>
#include<stack>
#include<deque>
#include<queue>
#include<list>
#define lowbit(x) (x & (-x))
const double eps = 1e-8;
inline int dcmp(double a, double b){
if(fabs(a - b) < eps) return 0;
return a > b ? 1 : -1;
}
typedef long long LL;
typedef unsigned long long ULL;
const int INT_INF = 0x3f3f3f3f;
const int INT_M_INF = 0x7f7f7f7f;
const LL LL_INF = 0x3f3f3f3f3f3f3f3f;
const LL LL_M_INF = 0x7f7f7f7f7f7f7f7f;
const int dr[] = {0, 0, -1, 1, -1, -1, 1, 1};
const int dc[] = {-1, 1, 0, 0, -1, 1, -1, 1};
const int MOD = 1e9 + 7;
const double pi = acos(-1.0);
const int MAXN = 100000 + 10;
const int MAXT = 10000 + 10;
using namespace std;
int f[MAXN];
double dp[MAXN];
int main(){
int N, M;
while(scanf("%d%d", &N, &M) == 2){
if(!N && !M) return 0;
memset(f, 0, sizeof f);
memset(dp, 0, sizeof dp);
while(M--){
int x, y;
scanf("%d%d", &x, &y);
f[x] = y;
}
for(int i = N - 1; i >= 0; --i){
if(f[i]) dp[i] = dp[f[i]];
else{
for(int j = 1; j <= 6; ++j){
dp[i] += dp[i + j] / 6;
}
++dp[i];
}
}
printf("%.4f\n", dp[0]);
}
return 0;
}

  

最新文章

  1. Oracle之nclob类型
  2. Linux连接Internet
  3. JAVA正则表达式:Pattern类与Matcher类详解(转)
  4. win7/win8远程桌面 server 2003 卡的问题
  5. angularjs封装bootstrap官网的时间插件datetimepicker
  6. Nginx配置优化的几个参数
  7. Checkstyle 简介 以及各版本下载地址
  8. 关于transition回调函数的几种写法
  9. GNU C中x++是原子操作吗?
  10. 关于模板中的动态取值 ---反射与javascript脚本编译
  11. 你真的会玩SQL吗?Top和Apply
  12. poj 1459 (最大流)
  13. 数字图像处理(MATLAB版)学习笔记(2)——第2章 灰度变换与空间滤波
  14. logback日志框架的简单使用
  15. 一脸懵逼学习Hdfs---动态增加节点和副本数量管理(Hdfs动态扩容)
  16. iOS:检测多媒体(相机、相册、麦克风)设备权限,弹框提示
  17. day056-58 django多表增加和查询基于对象和基于双下划线的多表查询聚合 分组查询 自定义标签过滤器 外部调用django环境 事务和锁
  18. Python 面向对象(三)
  19. GIS中栅格数据结构的显示与计算
  20. Golang框架Beego在Windows环境下小试牛刀

热门文章

  1. vue 父组件向子组件传参(笔记)
  2. 吴裕雄 Bootstrap 前端框架开发——Bootstrap 图片:将图片变为圆形 (IE8 不支持)
  3. linux下mysql允许远程连接
  4. metasploit扫描
  5. 2-10 就业课(2.0)-oozie:10、伪分布式环境转换为HA集群环境
  6. 微信小程序支付功能前端流程
  7. vue - @click 传参删除
  8. RAID与磁盘管理之——综合应用
  9. [Java] Eclipse 设置相同变量背景色高亮显示
  10. 查看Python安装目录 -- 一个命令