题目链接:https://vjudge.net/problem/UVA-10529

知识点:  概率与期望,DP。

题目大意:

  现要放置 \(n\) 个多米诺骨牌,且每放置一块多米诺骨牌有 \(P_l\) 的概率向左倒,其左边相邻的骨牌也会随之倒下;有 \(P_r\) 的概率向右倒,其右边相邻的骨牌同上。问要放置 \(n\) 块相连的一排骨牌所需要的放置次数的最小期望是多少?

  \(1 \le n \le 100\)

  \(0 < P_l + P_r \le 0.5\)

解题思路:

  我们用动态规划的方法来解决这个问题。

  设 \(dp(i)\) 为放置 \(i\) 块相连的一排骨牌所需要的放置次数的最小期望,我们先给出状态转移方程:

  \(dp(i) = min\{ dp(i), \frac{dp(l) \cdot P_l + dp(r) \cdot P_r + 1}{1-P_l-P_r} + dp(l) + dp(r) \mid 0 \le l \le i, r = i-1-l \}\)  

  上式中,我用 \(l\) 表示放置第 \(i\) 块骨牌(即最后一块)的时候左边的相连的骨牌数,\(r\) 则表示右边的。我们可以用 \((l,r)\) 来表示我们放置最后一块骨牌的位置,则当我们在 \((l,r)\) 放置最后一块骨牌时,放置这 \(i\) 块连续的骨牌所需要的次数的期望为 \(E = E(i) + dp(l) +dp(r)\),我们事先已经知道了 \(dp(k) \{0 \le k < i\}\),故重点就在于求解 \(E(i)\) ,即放置第 i 块所需的放置次数的期望。首先,我们需要知道:每放置一块多米诺骨牌有 \(1 - P_l - P_r\) 的概率不会倒。接下来,我们分成如下三种情况来讨论:

  1、放置一次即成功,有 \(1 - P_l - P_r\) 的概率。则放置次数的期望为:\(\frac{1}{1 - P_l - P_r}\) ;

  2、放置以后向左倒,有 \(P_l\) 的概率。我们需要先将左边的骨牌放置好,我们需要放置成功 \(dp(l)\) 次,每一次的成功概率都为 \(1 - P_l - P_r\),则需要的次数的期望为 \(\frac{dp(l)}{1-P_l-P_r}\),当然,我们也不能忘了乘上 \(P_l\),则最终的期望值为:\(\frac{P_l \cdot dp(l)}{1-P_l-P_r}\);

  3、放置以后向右倒同理。

  于是,我们不难推出:

  \(E = \frac{dp(l) \cdot P_l + dp(r) \cdot P_r +1}{1 - P_l - P_r} + dp(l) + dp(r)\)  .

  一切也就顺理成章了。

AC代码:

 #include <iostream>
#include <cstdio> using namespace std;
const int maxn=;
const double inf=0x7fffffff;
double dp[maxn];
int main()
{
int n;
double pl,pr;
while(scanf("%d",&n)==&&n){
scanf("%lf%lf",&pl,&pr);
for(int i=;i<=n;i++) dp[i]=inf;
dp[]=;
int l,r;
for(int i=;i<=n;i++){
for(l=;l<i;l++){
r=i--l;
dp[i]=min(dp[i],(dp[l]*pl+dp[r]*pr+)/(-pl-pr)+dp[l]+dp[r]);
}
}
printf("%.2lf\n",dp[n]);
}
return ;
}

  PS: 此题还有一种 \(O(nlog n)\) 和一种 \(O(n)\) 的算法,未完待续。

UVA10529 Dumb Bones (完成度:40%)的更多相关文章

  1. UVA10529 Dumb Bones

    UVA10529 Dumb Bones go to solution 设$f[i]$表示叠$i$个的骨牌的期望 $O(n)$做法 #include<iostream> #include&l ...

  2. 2018.09.09 UVa10529 - Dumb Bones(期望dp)

    传送门 期望dp好题. f[i]表示摆放i个的最小花费,于是f[i]可以从f[j]与f[i-j+1]转移过来了. 代码: #include<bits/stdc++.h> #define N ...

  3. Dumb Bones UVA - 10529[多米诺重构]

    Dumb Bones UVA - 10529   来自绿书p176  题意 你试图把一些多米诺骨牌排成直线,然后推倒它们.但是如果你在放骨牌的时候不小心把刚放的骨牌碰倒了,它就会把相临的一串骨牌全都碰 ...

  4. UVA 10529 - Dumb Bones(概率+区间dp)

    UVA 10529 - Dumb Bones option=com_onlinejudge&Itemid=8&category=518&page=show_problem&am ...

  5. UVA 10529 Dumb Bones 可能性dp 需求预期

    主题链接:点击打开链接 题意: 要在一条直线上摆多米诺骨牌. 输入n, l, r 要摆n张排,每次摆下去向左倒的概率是l, 向右倒的概率是r 能够採取最优策略.即能够中间放一段.然后左右两边放一段等, ...

  6. [UVA 10529]Dumb Bones

    题面在这里 题意 放\(n\)个相连的骨牌,每次放的时候有\(pl\)的概率往左倒,有\(pr\)的概率往右倒,骨牌倒的时候可能会打翻左边相邻或者右边相邻的骨牌,并引起连锁反应直到最后一个骨牌旁边没有 ...

  7. Dumb Bones UVA - 10529(概率dp)

    题意: 你试图把一些多米诺骨牌排成直线,然后推倒它们.但是如果你在放骨牌的时候不小心把刚放的骨牌碰倒了,它就会把相临的一串骨牌全都碰倒, 而你的工作也被部分的破坏了. 比如你已经把骨牌摆成了DD__D ...

  8. #11 UVA 10529 Dumb Bones

    题意: 放一堆排,每放一张,有pa的概率让左边的全倒,有pb的概率让右边全倒 问在最优策略下,最少要放几张才能摆放出n张 1<=n<=1000 题解: 这题应该还是很经典的 首先是期望部分 ...

  9. Dumb Bones(uva 10529)

    题意:给定n,表示要放n个骨牌,每次放下骨牌,有可能向左倒的概率为pl,向右倒的概率为pr,如果倒下,会将那一侧的骨牌全部推倒,可以选择位置先后放骨牌,问说一种放骨牌次数最少的期望是多少. /* 设d ...

随机推荐

  1. KMP & AC自动机

    KMP void kmp(char t[],char p[]) { int n=strlen(t),m=strlen(p); int *f=new int[m]; f[0]=f[1]=0; for(i ...

  2. mysql查询连接数

    最近公司的测试服务器数据库经常是连接爆满,几次加大了依旧满了. 明明只有几个人在用这个数据库,但是连接数到了三四百.于是就想是谁一直开着连接不释放,于是写了个SQL查了下连接使用情况. SQL如下: ...

  3. java中文乱码解决之道(七)—–JSP页面编码过程

    我们知道JSP页面是需要转换为servlet的,在转换过程中肯定是要进行编码的.在JSP转换为servlet过程中下面一段代码起到至关重要的作用. <%@ page language=" ...

  4. usermod,用户密码管理,mkpasswd命令

    passwd是更改用户密码的文件,如果在root下,我们可以直接输入这个命令更改密码[root@localhost ~]# passwd更改用户 root 的密码 .新的 密码:如果想更改其他用户的密 ...

  5. Mysql 开窗函数实战

    Mysql 开窗函数实战 Mysql 开窗函数在Mysql8.0+ 中可以得以使用,实在且好用. row number() over rank() over dense rank() ntile() ...

  6. Centos7网络配置( 网关、dns、ip地址配置)

    0.前提:设置VMware的虚拟网络编辑器 子网和网关设置   虚拟网络编辑器 1.配置DNS(可忽略) $vim /etc/resolv.conf nameserver 192.168.0.1 2. ...

  7. 背英语单词很困难,不妨学习一下词根词缀吧(每天10个词根、词缀)Part 3

    1.ir- 不,向内 例词: irregular=ir(不)-regular(规则的)=不规则的 irrigate=ir(向内)-rigate(浇水)=灌溉 2. kilo- 千 例词: kilogr ...

  8. Python(Redis 中 String/List/Hash 类型数据操作)

    1.下载 redis 模块 pip install redis 2.redis 数据库两种连接方式 简单连接 decode_responses=True,写入和读取的键值对中的 value 为 str ...

  9. 老师,你确定Java注释不会被执行吗?

    之前在博客上分享过一篇文章,涉及到 Java 中的注释,就信誓旦旦地写了一句话:"注释是不会被执行的!"结果,有小伙伴留言说,"老师,你确定吗?" 我这个人一直 ...

  10. Centos7 搭建bind9.9

    DNS服务器概述: DNS(Domain Name System),即域名系统. DNS服务器分为三种: 主域名服务器(Master Server).辅助域名服务器(Slave DNS).缓存服务器( ...