博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
UVa 10900 (连续概率、递推) So you want to be a 2n-aire?
阅读量:5054 次
发布时间:2019-06-12

本文共 935 字,大约阅读时间需要 3 分钟。

题意:

初始奖金为1块钱,有n个问题,连续回答对i个问题后,奖金变为2i元。

回答对每道题的概率在t~1之间均匀分布。

听到问题后有两个选择:

  • 放弃回答,拿走已得到的奖金
  • 回答问题:
    • 如果回答正确,奖金加倍
    • 如果回答错误,游戏结束,得不到奖金

分析:

d[i]表示答对i题后最大期望奖金,设回答对第i题的概率为p,

则回答第i题的期望奖金 = p × d[i]

考虑上不回答的情况,期望奖金最大值为max{2i-1, p*d[i]}

因为p在t~1均匀分布,所以d[i]等于分段函数max{2i-1, p*d[i]}在这个区间上的积分。

因为一段是常函数,一段是直线,所以积分很好求。

令p0 = max{t, 2i/d[i+1]}

  • p < p0,选择不回答,奖金期望为2i
  • p ≥ p0,选择回答,奖金期望为(1+p0)/2 * d[i+1]

根据全概率公式,第一种情况的概率为p1 = (p0 - t) / (1 - t)

d[i] = p1*2i + (1-p1)*(1+p0)/2 * d[i+1]

边界d[n] = 2n,答案为d[0]

1 #include 
2 #include
3 using namespace std; 4 5 const int maxn = 35; 6 double d[maxn]; 7 8 int main() 9 {10 //freopen("in.txt", "r", stdin);11 int n;12 double t;13 while(scanf("%d%lf", &n, &t) == 2 && n)14 {15 d[n] = (1 << n);16 for(int i = n-1; i >= 0; --i)17 {18 double p0 = max(t, (double)(1<
代码君

 

转载于:https://www.cnblogs.com/AOQNRMGYXLMV/p/4189098.html

你可能感兴趣的文章
查找 EXC_BAD_ACCESS 问题根源的方法
查看>>
日常报错
查看>>
list-style-type -- 定义列表样式
查看>>
Ubuntu 编译出现 ISO C++ 2011 不支持的解决办法
查看>>
Linux 常用命令——cat, tac, nl, more, less, head, tail, od
查看>>
VueJS ElementUI el-table 的 formatter 和 scope template 不能同时存在
查看>>
Halcon一日一练:图像拼接技术
查看>>
iOS设计模式 - 中介者
查看>>
centos jdk 下载
查看>>
HDU 1028 Ignatius and the Princess III(母函数)
查看>>
(转)面向对象最核心的机制——动态绑定(多态)
查看>>
token简单的使用流程。
查看>>
django创建项目流程
查看>>
Vue 框架-01- 入门篇 图文教程
查看>>
多变量微积分笔记24——空间线积分
查看>>
poi操作oracle数据库导出excel文件
查看>>
(转)Intent的基本使用方法总结
查看>>
Windows Phone开发(24):启动器与选择器之发送短信
查看>>
JS截取字符串常用方法
查看>>
Google非官方的Text To Speech和Speech Recognition的API
查看>>