题目链接: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. Libra教程之:Libra协议的关键概念

    文章目录 Libra协议 交易和状态 交易详解 账本状态详解 版本数据库 账户 账户地址 Proof 验证节点 存储 Libra协议 Libra协议是Libra区块链的基础,本文主要讲解Libra协议 ...

  2. Linux系统管理第五次作业 LVM逻辑卷 磁盘配额

    1.为主机增加80G SCSI 接口硬盘 2.划分三个各20G的主分区 [root@localhost ~]# fdisk /dev/sdf 欢迎使用 fdisk (util-linux 2.23.2 ...

  3. vue + ArcGIS 地图应用系列一:arcgis api本地部署(开发环境)

    封面 1. 下载 ArcGIS API for JavaScript 官网地址: https://developers.arcgis.com/javascript/3/ 下载地址:http://lin ...

  4. Hardware Introduction

    计算机硬件组成可以概括为下图: CPU CPU生产商主要是Intel和AMD. Intel的产品主要有四种: Celeron(赛扬):低端处理器 Pentium(奔腾):比赛扬强,比酷睿弱 Xeon( ...

  5. Codeforce-Ozon Tech Challenge 2020-A. Kuroni and the Gifts

    the i-th necklace has a brightness ai, where all the ai are pairwise distinct (i.e. all ai are diffe ...

  6. CF--思维练习--CodeForces - 220C Little Elephant and Shifts (STL模拟)

    ACM思维题训练集合 The Little Elephant has two permutations a and b of length n, consisting of numbers from ...

  7. unittest 管理用例生成测试报告

    # 登录方法的封装 from appium import webdriver from time import sleep from python_selenium.Slide import swip ...

  8. zabbix 数据库分区表配置

    下载 pwd /usr/local/zabbix/share/zabbix/externalscriptswget http://cactifans.hi-www.com/zabbix/partiti ...

  9. C#对象初始化器

    1.对象初始化器 Student objStu2 = new Student() { StudentId=, //属性之间使用","分隔 StudentName="小明& ...

  10. 自己封装函数,实现数组的内置方法indexOf的功能

    在学习或开发过程中,经常会有朋友需要使用到一个数组方法-indexOf,这里我们先来谈谈它的功能:返回指定数据所在的索引,如果没有则返回-1. 那么我们在使用时通常是直接使用它这个数组内置方法 今天这 ...