【NOIP2013模拟联考7】OSU

描述

Description

osu 是一款群众喜闻乐见的休闲软件。

我们可以把osu的规则简化与改编成以下的样子:

一共有n次操作,每次操作只有成功与失败之分,成功对应1,失败对应0,n次操作对应为一个长度为n的01串。在这个串中连续的x个1可以贡献x^3的分数,这x个1不能被其他连续的1所包含(也就是极长的一串1,具体见样例解释)

现在给出n,以及每个操作的成功率,请你输出期望分数,输出四舍五入后保留1位小数。

Input

输入文件osu.in的第一行有一个正整数n,表示操作个数。接下去n行每行有一个[0,1]之间的实数,表示每个操作的成功率。

Output

输出文件osu.out只有一个实数,表示答案。答案四舍五入后保留1位小数。

Sample Input

3

0.5

0.5

0.5

Sample Output

6.0

【样例说明】

000分数为0,001分数为1,010分数为1,100分数为1,101分数为2,110分数为8,011分数为8,111分数为27,总和为48,期望为48/8=6.0

Data Constraint

30%的数据 n<=20

60%的数据 n<=1000

100%的数据 n<=100000

分析

30分做法:暴力乱搞

60分做法:

设fi表示i选0的期望。设an+1=0

fi=∑0<=j<i(fj+(i−j−1)3(1−pj))(1−pi)⎛⎝∏j<k<ipk⎞⎠

从fj转移到fi时,(j,i)这段区间都要选1,两端要选0。

fj已经算过它选0的概率的,不用再算一遍。

时间复杂度O(n2)

100分做法:

设第i次操作时,前面末尾1的长度为x

选0:对答案的贡献为0

选1:对答案的贡献为((x+1)3−x3)pi

设E(x3)=∑k3∗Px=k

那么E((x+1)3)=∑(k+1)3∗Px=k

展开E((x+1)3),将E(x3)代入之,得E((x+1)3)=E(x3)+3E(x2)+3E(x)+E(1)

然后类似地,维护E(x2),E(x)。

具体见程序

代码

#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
double cube(int x){return (double)x*x*x;}
int n;
double ans;
double g1[100001],g2[100001];
int main()
{
freopen("osu.in","r",stdin);
freopen("osu.out","w",stdout);
scanf("%d",&n);
int i;
double a;
for (i=1;i<=n;++i)
{
scanf("%lf",&a);
g1[i]=(g1[i-1]+1)*a;
g2[i]=(g2[i-1]+2*g1[i-1]+1)*a;
ans+=(3*g2[i-1]+3*g1[i-1]+1)*a;
}
printf("%.1lf",ans);
return 0;
}

最新文章

  1. 吉特仓库管理系统(开源)-如何在网页端启动WinForm 程序
  2. getGlobalVisibleRect和getLocalVisibleRect
  3. attr和prop区别
  4. Android之Adapter用法总结-(转)
  5. Hadoop之Hive UDAF TopN函数实现
  6. HDU5806:NanoApe Loves Sequence Ⅱ(尺取法)
  7. 制作计算器的代码(C#)
  8. 一次plsql 问题记录
  9. keil多文件组织方法
  10. JavaScript Window - 浏览器对象模型
  11. C# linq语句学习
  12. 关于python的感想和turtle作图
  13. 用好lua+unity,让性能飞起来——关于《Unity项目常见Lua解决方案性能比较》的一些补充
  14. 根据成绩输出对应的等级(使用if多分支和switch语句分别实现)
  15. 安装使用swoole
  16. python: 多态与虚函数;
  17. git打tag
  18. Wi-Fi Mesh网络技术
  19. wxWidgets:wxApp概述
  20. 关于Mybatis的Example(and ,or )应用

热门文章

  1. leetcode-241-为运算表达式设置优先级*
  2. POJ-3264-Balanced Lineup-线段树模板题-查询区间内最大值和最小值之差
  3. day 80 Vue学习一之vue初识
  4. Java性能优化的50个细节,我必须分享给你!
  5. wpf datepicker 样式
  6. SpringBoot集成JPA根据实体类自动生成表
  7. java、jsp导出excel功能备份
  8. AM历史消息及文件记录删除
  9. redis笔记_源码_内存分配
  10. thinkphp 动态查询