题面

题解

期望dp入门题

设\(f[i][j]\)为到\(i\)时间有\(j\)个人上了电梯的概率, 我们可以得到转移方程

\[f[i][j]=\begin{cases}f[i-1][j]\cdot(1-p),&j=0\\f[i-1][j-1]\cdot p+f[i-1][j]\cdot(1-p),&j\in[1,n)\\f[i-1][n]+f[i-1][n-1]\cdot p,&j=n\end{cases}
\]

Code

#include <algorithm>
#include <iostream>
#include <cstring>
#include <cstdlib>
#include <cstdio>
#include <vector>
#define itn int
#define reaD read
#define N 2005
using namespace std; int n, t;
double f[N][N], p, ans; inline int read()
{
int x = 0, w = 1; char c = getchar();
while(c < '0' || c > '9') { if (c == '-') w = -1; c = getchar(); }
while(c >= '0' && c <= '9') { x = x * 10 + c - '0'; c = getchar(); }
return x * w;
} int main()
{
n = read(); scanf("%lf", &p); t = read();
f[0][0] = 1;
for(int i = 1; i <= t; i++)
{
f[i][0] = f[i - 1][0] * (1 - p);
for(int j = 1; j < n; j++) f[i][j] = f[i - 1][j - 1] * p + f[i - 1][j] * (1 - p);
f[i][n] = f[i - 1][n] + f[i - 1][n - 1] * p;
}
for(int i = 1; i <= n; i++) ans = (ans + (double) f[t][i] * i);
printf("%lf\n", ans);
return 0;
}

最新文章

  1. ExtJs基础知识总结:自定义弹窗和ComboBox自动联想加载(四)
  2. RSA加密算法的简单案例
  3. Linux下gcc与gdb简介
  4. iOS开发(OC)中的命名规范
  5. iOS基础之Xcode 8相关
  6. 关于Bugzilla WebService接口
  7. Writing the first draft of your science paper — some dos and don’ts
  8. logstash中的redis插件
  9. Java常见排序算法之直接选择排序
  10. rank() | dense_rank() | row_number() over(PARTITION BY sex order by age desc ) 的区别
  11. rapidxml对unicode的支持
  12. Java日志记录的5条规则
  13. impdp/expdp 总结
  14. 了解Linux 命名空间
  15. Swift - 跑酷游戏开发(SpriteKit游戏开发)
  16. WPF 设置WebBrowser控件不弹脚本错误提示框
  17. CONSOLE_SCREEN_BUFFER_INFO 结构体
  18. Newbit 启用淘宝店域名
  19. APP多开教程
  20. JavaScript:我总结的数组API

热门文章

  1. Flask:上下文管理
  2. yolov3应该什么时候停止训练?
  3. mybatis-plus使用Oracle函数生成主键
  4. [leetcode] 题解记录 11-20
  5. left join 和 inner join 区别和优化
  6. jboss日志的自定义
  7. 通过sql判断时间区间是否存在数据
  8. 如何关闭Win10系统的时间轴功能?
  9. odoo 字段组件
  10. Intellij IDEA导入java项目看不到左边的项目目录结构