update 9.20:本篇题解已经被\(yyb\)证明是出锅的

这道题目最后的式子看上去是很简单的,不到10行就码完了,但是求式子的过程并没有那么简单。

很容易想到一种枚举思路:

因为每一段连续的1都有一个结束位置,我们从左到右枚举这个结束位置,

再枚举在这个位置结束的连续的1的长度,最后把贡献加入答案。

用式子写出来就是:

\[\sum_{i=1}^{n}\sum_{j=1}^{i}p_{i,j}j^3
\]

其中\(p_{i,j}\)表示结束位置为\(i\)的连续1串,其长度为\(j\)的概率

\(p_{i,j}\)可以预处理,这样做是\(O(n^2)\)的

如何做到\(O(n)\)?考虑差分

我们先从一个简单的问题开始

现在你有一个取值为\([1,a]\)的整数随机数\(x\),它取\(i(1\le i\le a)\)的几率为\(p_i\),求\(E(x)\)

注意这里的\(p\)和前面的有所不同

根据数学知识我们知道\(E(x)=\sum_{i=1}^{a}i\times p_i\)

现在我们把这个求和式子做一下变换:

\[\sum_{i=1}^{a}i\times p_i=\sum_{i=1}^{a}\sum_{j=1}^{i}p_i=\sum_{i=1}^{a}\sum_{j=i}^{a}p_j
\]

第一个等号显然

第二个等号交换了一下求和的顺序(如果不知道为什么的可以手画一下\(a\)较小的情况)

我们记\(\sum_{j=i}^{a}p_j=f_i\),它表示随机数的取值\(\ge i\)的概率

于是我们现在得到了另一个公式:

\[E(x)=\sum_{i=1}^{a}i\times p_i=\sum_{i=1}^{a}f_i
\]

从另一个角度理解这个式子:

当\(a=1\)时,显然\(E(x)=f_1=p_1\)

当\(a=2\)时,我们如果继续使用\(f_1=p_1+p_2\)作为答案,会发现我们把\(x=2\)对答案的贡献给算少了;

本来应该是\(2\times p_2\),我们的原答案\((f_1)\)里只有一个\(p_2\)

因此我们还要加上一个\(f_2\),即\(f_1+f_2\)

当\(a=3\)时,我们如果继续使用\(f_1+f_2=p_1+2p_2+2p_3\)作为答案,

会发现我们把\(x=3\)对答案的贡献给算少了;

本来应该是\(3\times p_3\),我们的原答案\((f_1+f_2)\)里只有两个\(p_3\)

因此我们还要加上一个\(f_3\),即\(f_1+f_2+f_3\)

故每当\(x\)的可能取值范围扩大后,我们就需要对于原来我们给出的期望进行补足

回到这道题,我们要算的是\(\sum_{i=1}^{n}\sum_{j=1}^{i}p_{i,j}j^3\)

这里的\(p\)是前面的\(p_{i,j}\)

我们可以换成求\(f_{i,j}\),它表示结束位置为\(i\)的连续1串,其长度\(\ge j\)的概率

如果我们只要算\(\sum_{i=1}^{n}\sum_{j=1}^{i}p_{i,j}j\)(没有了立方)

那么答案变成\(\sum_{i=1}^{n}\sum_{j=1}^{i}f_{i,j}\)

而这里的\(f_{i,j}\)非常好求,就是\(\prod_{k=i-j+1}^{i}s_k\),

\(s_k\)表示第\(k\)个位置为\(1\)的概率

因为只要\((i-j+1)\)到\(i\)的位置全部为\(1\),那么连续1串的长度一定\(\ge j\)

如果我们记\(x_i=\sum_{j=1}^{i}f_{i,j}\),那么递推式就是

\[x_i=p_ix_{i-1}+p_i
\]

这就是大家喜闻乐见的第一个递推式

但是我们现在要算\(Ans=\sum_{i=1}^{n}\sum_{j=1}^{i}p_{i,j}j^3\)

使用前面的补足思想,当\(x=i+1\)的时候,\(x^3\)需要对之前补足的贡献是\((3i^2+3i+1)\)

因此

\[Ans=\sum_{i=1}^{n}\sum_{j=1}^{i}p_{i,j}j^3=\sum_{i=1}^{n}\sum_{j=1}^{i}[3(j-1)^2+3(j-1)+1]f_{i,j}
\]

首先记\(y_i=\sum_{j=1}^{i}j^2p_{i,j}=\sum_{j=1}^{i}[2\times (j-1)+1]f_{i,j}\),

由于\(y_{i-1}\times p_i=\sum_{j=1}^{i-1}[2\times (j-1)+1]f_{i-1,j}\times p_i=\sum_{j=2}^{i}[2\times (j-2)+1]f_{i,j}\),

故\(y_i-y_{i-1}\times p_i=\sum_{j=2}^{i}2f_{i,j}+f_{i,1}=2x_{i-1}p_i+p_i\)

因此\(y_i\)的递推式为

\[y_i=(y_{i-1}+2\times x_{i-1}+1)\times p_i
\]

这就是大家喜闻乐见的第二个递推式

这样我们可以推到次数为\(3\)的情况,

记\(dis_i=\sum_{j=1}^{i}p_{i,j}j^3=\sum_{j=1}^{i}f_{i,j}(3j^2+3j+1)\),

仿照\(y_i\)的方法我们有大家喜闻乐见的第三个递推式

\[dis_i=(dis_{i-1}+3\times y_{i-1}+3\times x_{i-1}+1)\times p_i
\]

使用这三个递推式即可解决问题

虽然这三个递推式并不好理解

但难道我们只是为了\(AC\)数而做题的吗?

#include<bits/stdc++.h>
using namespace std;
int n;dd a[N],x[N],y[N],dis[N];
int main()
{
n=read();
for(RG int i=1;i<=n;i++){
scanf("%lf",&a[i]);
x[i]=(x[i-1]+1)*a[i];
y[i]=(y[i-1]+2*x[i-1]+1)*a[i];
dis[i]=dis[i-1]+(3*y[i-1]+3*x[i-1]+1)*a[i];
}
printf("%.1lf\n",dis[n]);
return 0;
}

[luogu1654]OSU!的更多相关文章

  1. 2014 Asia AnShan Regional Contest --- HDU 5078 Osu!

    Osu! Problem's Link:   http://acm.hdu.edu.cn/showproblem.php?pid=5078 Mean: 略. analyse: 签到题,直接扫一遍就得答 ...

  2. UVALive 7270 Osu! Master (阅读理解题)

    题目:传送门. 题意:阅读理解题,是一个osu的游戏,问得分.把题目翻译过来就是如果出现S或者BC后面跟的是1,ans就加1. #include <iostream> #include & ...

  3. Codeforces Round #146 (Div. 1) B. Let's Play Osu! dp

    B. Let's Play Osu! 题目连接: http://www.codeforces.com/contest/235/problem/B Description You're playing ...

  4. BZOJ 4318: OSU! 期望DP

    4318: OSU! 题目连接: http://www.lydsy.com/JudgeOnline/problem.php?id=4318 Description osu 是一款群众喜闻乐见的休闲软件 ...

  5. codeforces 235 B. Let's Play Osu!

    You're playing a game called Osu! Here's a simplified version of it. There are n clicks in a game. F ...

  6. bzoj4318: OSU!&&CF235BLet's Play Osu!

    题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=4318 4318: OSU! Time Limit: 2 Sec  Memory Limit ...

  7. Tsinsen-A1490 osu! 【数学期望】

    问题描述 osu!是一个基于<押忍!战斗!应援团><精英节拍特工><太鼓达人>等各种音乐游戏做成的一款独特的PC版音乐游戏.游戏中,玩家需要根据音乐的节奏,通过鼠标 ...

  8. bzoj-4318 OSU! 【数学期望】

    Description osu 是一款群众喜闻乐见的休闲软件.  我们可以把osu的规则简化与改编成以下的样子:  一共有n次操作,每次操作只有成功与失败之分,成功对应1,失败对应0,n次操作对应为1 ...

  9. hdu 5078 Osu! (2014 acm 亚洲区域赛鞍山 I)

    题目链接:http://acm.hdu.edu.cn/showproblem.php? pid=5078 Osu! Time Limit: 2000/1000 MS (Java/Others)     ...

随机推荐

  1. Java:break和continue关键字的作用

    二者的作用和区别 1. break:直接跳出当前循环体(while.for.do while)或程序块(switch).其中switch case执行时,一定会先进行匹配,匹配成功返回当前case的值 ...

  2. ORB-SLAM(六)MapPoint与Map

    地图点可以通过关键帧来构造,也可以通过普通帧构造,但是最终,必须是和关键帧对应的,通过普通帧构造的地图点只是临时被Tracking用来追踪用的. 构造函数(地图点3D坐标及其参考帧): // 参考帧是 ...

  3. 创龙DSP6748学习之RS485收发

    1. 先看下原理图,第一个问题,RS485其实就是使用的串口USART1,同时485的输出脚之间接120欧姆的电阻. 遇到个问题,为什么有两个使能引脚?还有RS485_A和RS485_B为什么分别接上 ...

  4. 说说NSCache优于NSDictionary的几点

    1.NSCache可以提供自动删减缓存功能,而且保证线程安全,与字典不同,不会拷贝键.2.NSCache可以设置缓存上限,限制对象个数和总缓存开销.定义了删除缓存对象的时机.这个机制只对NSCache ...

  5. 错误码:2003 不能连接到 MySQL 服务器在 (10061)

    今天在ubuntu上安装了mysql服务器,在windows上用客户端软件连接mysql服务器时,出现错误: 错误码: 不能连接到 MySQL 服务器在 () 折腾来折腾去没搞好,防火墙也关了,330 ...

  6. 【label】标签组件说明

    label标签组件 用来改进表单组件的可用性,使用for属性找到对应的id,或者将控件放在该标签下,当点击时,就会触发对应的控件.目前可以绑定的控件有:<button/>, <che ...

  7. Java异常层次结构

    1. 如果是不可查异常(unchecked exception),即Error.RuntimeException或它们的子类,那么可以不使用throws关键字来声明要抛出的异常,编译仍能顺利通过,但在 ...

  8. 【转】AMD 的 CommonJS wrapping

    其实本文的标题应该是「为什么我不推荐使用 AMD 的 Simplified CommonJS wrapping」,但太长了不好看,为了美观我只能砍掉一截. 它是什么? 为了复用已有的 CommonJS ...

  9. 关于onclick和addeventlistener('click'),click的整理

    代码 $(function(){ $("#btn").click(function(){ console.log(2) }) $("#btn").click(f ...

  10. 【转】C++后台开发之我见

    工作也快两年了,偶然看到自己以前写过的一些技术博客,发现自己自毕业后一直没有更新过自己的技术博客,趁现在是刚过完春节快要回公司工作之际,谈谈我个人对后台开发的一些个人见解,希望能够对在校的学生或者刚刚 ...