能想到是概率DP,但是定义状态dp[i][j]第i天剩j个麻球。然后麻球数量可能会繁殖到非常多,状态太多数组开不下,然后就不会了。

感觉自己总是轻易就放弃了,还是应该再思考一下,一般遇到这种想到DP但是数组开不下或者转移方程找不到或者转移方程太复杂的时候就应该想想可不可以优化,而不是直接就放弃。开不下就把状态定义得简单一些,看看是不是有哪些维是没必要记录,而只需要特别处理一下就好,或者重新开一个定义状态的思路。至于转移方程的问题我只能说首先状态定义要足够好,其次思路要再灵活一点。

本道题有一个特点就是每个麻球的繁殖是独立的,所以只要求出单个麻球的情况,然后再用公式算出总的情况。

具体就是说,定义状态dp[i],表示一个麻雀在第i天全部死亡的概率。或者说i天后全部死亡的概率。

这样就有状态转移方程dp[i]=P0+P1*dp[i-1]^1+P2*dp[i-1]^2+P3*dp[i-1]^3+......P(n-1)*dp[i-1]^(n-1)。

Pj*dp[i-1]^j的意思就是这一个麻球第一天生了j个麻球,然后这j个麻球在剩下的i-1天全部死亡的概率,加起来就是答案。

递归边界是dp[0]=0。因为第一天一定有1个麻球。

答案是dp[m]^k。每个麻球的繁殖是独立的,根据乘法原理,全部乘起来就是答案。

可以用记忆化搜索实现。

代码

#include<bits/stdc++.h>
#define maxn 1010
using namespace std;int n,k,m;
double P[maxn];
double f[maxn];
int vis[maxn];double mp(double x,int n)
{double ret=1;while(n){if(n&1) ret*=x;x*=x;n>>=1;}return ret;
}double d(int day)
{if(vis[day]) return f[day];vis[day]=true;double& ans=f[day]=0;if(!day) return ans=0;for(int i=0;i<n;i++)ans+=P[i]*pow(d(day-1),i);return ans;
}int main()
{int T;scanf("%d",&T);for(int t=1;t<=T;t++){scanf("%d %d %d",&n,&k,&m);for(int i=0;i<n;i++)scanf("%lf",&P[i]);memset(vis,0,sizeof(vis));printf("Case #%d: %.7lf\n",t,pow(d(m),k));}return 0;
}

概率DP,递推(麻球繁殖,UVA 11021)相关推荐

  1. CF935D Fafa and Ancient Alphabet 概率dp(递推)

    D. Fafa and Ancient Alphabet (简洁题意请往下翻) time limit per test 2 seconds memory limit per test 256 mega ...

  2. Two Arrays(DP递推)

    You are given two integers nn and mm. Calculate the number of pairs of arrays (a,b)(a,b) such that: ...

  3. HDU 4489 (DP递推计数)

    DP 递推计数 题意: 这是一道比较神奇的题,很考验思维:有n个高低不同的人,现在需要进行排列,排列一定要满足两种方式 高低高··· 低高低··· 求出有多少排列方式. 思路: 我们的切入点是第i个人 ...

  4. 动态规划入门之dp递推~

    欢迎访问https://blog.csdn.net/lxt_Lucia-- 宇宙第一小仙女\(^o^)/--萌量爆表求带飞=≡Σ((( つ^o^)つ~ dalao们点个关注呗-- 本篇文章重在递推,不 ...

  5. hdu 1723 DP/递推

    题意:有一队人(人数 ≥ 1),开头一个人要将消息传到末尾一个人那里,规定每次最多可以向后传n个人,问共有多少种传达方式. 这道题我刚拿到手没有想过 DP ,我觉得这样传消息其实很像 Fibonacc ...

  6. POj 3420 Quad Tiling 状态压缩DP+递推+矩阵快速幂

    哈哈,写了好久的,总算对了. 接下来介绍两种思路: 先介绍一种   递推+矩阵的快速幂的方法 一种DP的思想考虑4×n的最后一列  ,可以放的方法一共有5种 1.放4个 1×2  则 为dp[n-2] ...

  7. BZOJ 3329: Xorequ(数位dp+递推)

    传送门 解题思路 可以把原式移项得\(x\)^\(2x\)=\(3x\),而\(x+2x=3x\),说明\(x\)二进制下不能有两个连续的\(1\).那么第一问就是一个简单的数位\(dp\),第二问考 ...

  8. Power oj2498/DP/递推

    power oj 2498 /递推 2498: 新年礼物 Time Limit: 1000 MS Memory Limit: 65536 KB Total Submit: 12 Accepted: 3 ...

  9. HDU-5965 扫雷(dp / 递推)

    传送门 扫雷游戏是晨晨和小璐特别喜欢的智力游戏,她俩最近沉迷其中无法自拔. 该游戏的界面是一个矩阵,矩阵中有些格子中有一个地雷,其余格子中没有地雷. 游戏中,格子可能处于己知和未知的状态.如果一个己知 ...

最新文章

  1. 信息系统项目管理师教程章节重点考点汇总(1)绪论重点
  2. cursoradpter自动更新
  3. GetWindowText和GetDlgItemText的区别
  4. Cracked me --1--Acid_burn
  5. 微信程序短视频去水印源码 开源产品未加密未授权相关文章
  6. PostgreSql 分页limit
  7. 换一种方式去思考--microsoft for win server03
  8. Springboot,log文件配置时,logging.file.name与logging.file
  9. 2014.4.21 福州 晴 离京第一次面试(某天) 失败啊
  10. hdu 1087 Super Jumping! Jumping! Jumping! 解题报告
  11. 设计模式之建造者(builder)模式
  12. 单片机c语言1602怎么接线,lcd1602中文资料分享:lcd1602接线图_lcd1602与单片机连接图 - 全文...
  13. 数字图像处理冈萨雷斯——开始
  14. 通过IP地址连接两台电脑
  15. autoquad源码分析1
  16. C语言循环输出能被3整除的数
  17. 安卓应用禁止分屏模式方法
  18. 世界上最神奇的数字:142857,看似平凡的数字,为什么说他最神奇呢?——The world's most amazing number: 142857...
  19. vue中使用woo.js + animate.css
  20. VVC参考软件的下载安装

热门文章

  1. Linux软件仓库的搭建
  2. Sailfish应用开发入门(一)Windows 安装Sailfish,创建第一个Sailfish APP
  3. 下载 Visual Studio 2010 (SP1) Service Pack 1
  4. 基于Android Q电池服务分析
  5. VS 2017 OCX
  6. 火车头采集器采集图片文章详细 教程
  7. 火车头如何html发布,火车头采集器教程:WEB在线发布模块的修改
  8. 企业数字化转型之传统IT架构改造
  9. seo外链建设(如何正确做好seo网站外链建设)
  10. JVM2-性能监控故障处理工具