多米诺骨牌问题 概率DP

题目描述

准备一个m行n列的二维多米诺骨牌进行游戏。

游戏的目标是让二维的多米诺骨牌全部倒下。一个多米诺骨牌倒下的时候,有P的概率往下一列倒,有Q的概率往下一行倒,并触碰该方向上与其相邻的骨牌。

当一个倒下完成的时候,需要从第1行的第1列开始检查,然后检查第1行的第2列,… ,第m行的第1列,第m行的第2列…当检查到有一块骨牌没有倒下,就需要触碰当前骨牌。

问总共触碰骨牌的期望值。

输入

第一行包括两个正整数m和n,表示当前二维多米诺的长和宽。
接下来m行,每行n个数字表示第[i][j]个多米诺骨牌往下倒的概率。
接下来m行,每行n个数字表示第[i][j]个多米诺骨牌往右倒的概率。

输出

触碰的期望

分析

以dp[i][j]表示i行j列的多米诺骨牌被手动触碰的概率。

第一行第一列个多米诺骨牌是一定要触碰的,其被触碰的概率为1。

第i行第j列个多米诺骨牌被手动触碰的情况为:
- 上面一行的多米诺不往下倒,即 1 - down[i-1][j]
- 左边一行的多米诺不往右倒,即 1 - right[i][j-1]

由上可得:

dp[i][j] = (1 - down[i-1][
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值