Tyvj1952 Easy OSU
来源:互联网 发布:阳光网络问政 编辑:程序博客网 时间:2024/06/07 00:02
EASY
对于每一位分别计算对答案的贡献,因为期望具有可加性,所以E[i]相加就是最后答案
l记录到当前位最大连续1的长度
s[i]=='o',第i位对答案的贡献= (l+1)^2-l^2=2*l+1;l=l+1;
s[i]=='x' 第i位对答案的贡献=0 ,l=0
s[i]=='?' 0.5的概率为1,贡献2*l+1;
0.5的概率为0,贡献0
l=0.5*(l+1)+0.5*0
#include<iostream>#include<cstdio>#include<cstring>#define N 100005using namespace std;int n;double t,l[N],l2[N];int main(){ double ans=0.0; scanf("%d",&n); for(int i=1;i<=n;i++) { scanf("%lf",&t); ans+=t*((double)3.0*l2[i-1]+(double)3.0*l[i-1]+(double)1.0); l[i]=(l[i-1]+1)*t; l2[i]=(l2[i-1]+2.0*l[i-1]+1)*t; } printf("%0.1lf",ans); // while(1); return 0;}
OSU
方法和上面差不多,只是特别注意平方的期望和期望的平方不同,所以开两个数组,f[i]表示前i位长度的期望,g[i]表示前i位长度的平方的期望
对于每一位的贡献=(l+1)^3-l^3=3*l^2+3*l+1=3*g[i]+3*f[i]+1
f[i]很好求,按照上面的方法分类讨论直接求
此时,前i-1位的长度为f[i-1],如果下一位为1,则
g[i]=pi*g[i-1]=pi*E[(f[i-1]+1)^2]=pi*E[f[i-1]^2+2*f[i-1]+1]=E(f[i-1]^2)+2*E(f[i-1])+1(E表示期望)
所以g[i]=g[i+1]+2*f[i-1]+1;
#include<iostream>#include<cstdio>#include<cstring>#define N 100005using namespace std;int n;double t,l[N],l2[N];int main(){ double ans=0.0; scanf("%d",&n); for(int i=1;i<=n;i++) { scanf("%lf",&t); ans+=t*((double)3.0*l2[i-1]+(double)3.0*l[i-1]+(double)1.0); l[i]=(l[i-1]+1)*t; l2[i]=(l2[i-1]+2.0*l[i-1]+1)*t; } printf("%0.1lf",ans); // while(1); return 0;}
阅读全文
0 0
- Tyvj1952 Easy OSU
- BZOJ3450: Tyvj1952 Easy
- 【bzoj3450】 Tyvj1952 Easy
- [BZOJ3450] Tyvj1952 Easy
- bzoj3450 Tyvj1952 Easy
- BZOJ3450 Tyvj1952 Easy
- BZOJ 3450 Tyvj1952 Easy
- 期望【bzoj3450】Tyvj1952 Easy
- [BZOJ3450] Tyvj1952 Easy
- BZOJ3450: Tyvj1952 Easy
- bzoj 3450: Tyvj1952 Easy
- bzoj3450: Tyvj1952 Easy
- BZOJ3450: Tyvj1952 Easy
- 【bzoj3450】 Tyvj1952 Easy
- 3450: Tyvj1952 Easy
- BZOJ 3450 Tyvj1952 Easy
- bzoj3450: Tyvj1952 Easy
- BZOJ 3450: Tyvj1952 Easy
- PAT乙级 1033. 旧键盘打字(20)--字符ASCII码的应用
- SBC介绍
- 安卓文件保存、读取工具类,可以直接用,包含路径说明
- PAT乙级 1034. 有理数四则运算(20)
- javascript 判断字符串是否包含某字符串,String对象中查找子字符,indexOf
- Tyvj1952 Easy OSU
- 20170726 jQuery练习题 表格操作练习题
- 大家好
- HDU6034(多校联合B题,25进制模拟)
- QT-继承QWidget 设置样式无效解决
- PAT乙级 1035. 插入与归并(25)--模拟插入归并算法
- 9.内容文字移出
- 使自己的mysql数据库可以被远程登录
- Oracle中的序列