BZOJ 4318 OSU! (概率DP)
题意
中文题面,难得解释了 题目传送门
分析
- 考虑到概率DPDPDP,显然可以想到f(i,j)f(i,j)f(i,j)表示到第iii位末尾有jjj个111的期望值。最后输出f(n+1,0)f(n+1,0)f(n+1,0)即可
- 但 n<=100000n<=100000n<=100000
- xxx表示连续的111的个数。所以想想怎么可以得到 x3x^3x3。
- 有 x3=(x−1)3+3(x−1)2+3(x−1)+1x^3=(x-1)^3+3(x-1)^2+3(x-1)+1x3=(x−1)3+3(x−1)2+3(x−1)+1
- 用EEE表示期望,记p[i]p[i]p[i]表示第iii位选111的概率,则E(x3)=( E((x−1)3)+E(3(x−1)2)+E(3(x−1))+E(1) )∗p[i]E(x^3)=(\ E((x-1)^3)+E(3(x-1)^2)+E(3(x-1))+E(1)\ )*p[i]E(x3)=( E((x−1)3)+E(3(x−1)2)+E(3(x−1))+E(1) )∗p[i]
- 那么我们假设f1f1f1表示存在于末尾的xxx的期望值;f2f2f2表示存在于末尾的x2x^2x2的期望值;f3f3f3表示前面的所有x3x^3x3的期望值,也就是答案。
- 转移方程式就为:
f3(i)=f3(i−1)+(3f2(i−1)+3f1(i−1)+1)∗p[i]f2(i)=(f2(i−1)+2f2(i−1)+1)∗p[i]f1(i)=(f1(i−1)+1)∗p[i]\begin{aligned}f3(i)&=f3(i-1)+(3f2(i-1)+3f1(i-1)+1)*p[i]\\
f2(i)&=(f2(i-1)+2f2(i-1)+1)*p[i]\\
f1(i)&=(f1(i-1)+1)*p[i]\end{aligned}f3(i)f2(i)f1(i)=f3(i−1)+(3f2(i−1)+3f1(i−1)+1)∗p[i]=(f2(i−1)+2f2(i−1)+1)∗p[i]=(f1(i−1)+1)∗p[i] - 本来第一个方程式看起来有点奇怪,其实那是合并之后的结果。我们记LastLastLast为i−1i-1i−1之前的已经完结的E(x3)E(x^3)E(x3)的总和,这一部分只是为了为最终输出的答案做贡献才放在f3f3f3里。那么剩下的记为NowNowNow,就是未完结、存在于末尾的E(x3)E(x^3)E(x3)。有Last+Now=f3(i−1)Last+Now=f3(i-1)Last+Now=f3(i−1)
- 假如这个位置选了000,那么不会再往后做贡献,但是要把这一部分加到最终答案里面去。这一部分值为Now∗(1−p[i])Now*(1-p[i])Now∗(1−p[i])
- 否则将会对后面产生贡献,值为Now∗p[i]Now*p[i]Now∗p[i],其实也就是充当E(x3)=( E((x−1)3)+E(3(x−1)2)+E(3(x−1))+E(1) )∗p[i]E(x^3)=(\ E((x-1)^3)+E(3(x-1)^2)+E(3(x-1))+E(1)\ )*p[i]E(x3)=( E((x−1)3)+E(3(x−1)2)+E(3(x−1))+E(1) )∗p[i]中的E((x−1)3)E((x-1)^3)E((x−1)3)
- 所以f3(i)=Last+Now∗(1−p[i])+(Now+3f2(i−1)+3f1(i−1)+1)∗p[i]=Last+Now∗((1−p[i)]+p[i])+(3f2(i−1)+3f1(i−1)+1)∗p[i]=Last+Now+(3f2(i−1)+3f1(i−1)+1)∗p[i]=f3(i−1)+(3f2(i−1)+3f1(i−1)+1)∗p[i]\begin{aligned}f3(i)&=Last+Now*(1-p[i])+(Now+3f2(i-1)+3f1(i-1)+1)*p[i]\\&=Last+Now*((1-p[i)]+p[i]) + (3f2(i-1)+3f1(i-1)+1)*p[i]\\&=Last + Now+ (3f2(i-1)+3f1(i-1)+1)*p[i]\\&=f3(i-1)+(3f2(i-1)+3f1(i-1)+1)*p[i]\end{aligned}f3(i)=Last+Now∗(1−p[i])+(Now+3f2(i−1)+3f1(i−1)+1)∗p[i]=Last+Now∗((1−p[i)]+p[i])+(3f2(i−1)+3f1(i−1)+1)∗p[i]=Last+Now+(3f2(i−1)+3f1(i−1)+1)∗p[i]=f3(i−1)+(3f2(i−1)+3f1(i−1)+1)∗p[i]
- 而且DPDPDP时不用开数组
AC Code(300B)
#include <bits/stdc++.h>
using namespace std;
int main () {
int n;
scanf("%d", &n);
double f1 = 0, f2 = 0, f3 = 0, p;
while(n--) {
scanf("%lf", &p);
f3 += (3*f1 + 3*f2 + 1) * p;
f2 = (f2 + 2*f1 + 1) * p;
f1 = (f1 + 1) * p;
}
printf("%.1f\n", f3);
}
BZOJ 4318 OSU! (概率DP)的更多相关文章
- BZOJ 4318: OSU! 期望DP
4318: OSU! 题目连接: http://www.lydsy.com/JudgeOnline/problem.php?id=4318 Description osu 是一款群众喜闻乐见的休闲软件 ...
- bzoj 4318 OSU 概率期望dp
可以发现:f[i]转移到f[i+1]只和最后一串1的长度和平方有关, 因为如果新加的位置是1,贡献就是(x+1)^3-x^3=3x^2+3x+1,否则为0: 所以对于每一个位置,处理出期望的f,x和x ...
- bzoj 4318 OSU! —— 期望DP
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4318 期望DP,因为平方的期望不等于期望的平方,所以用公式递推: 第一次推错了囧,还是看这位 ...
- BZOJ - 4318: OSU! (期望DP&Attention)
Description osu 是一款群众喜闻乐见的休闲软件. 我们可以把osu的规则简化与改编成以下的样子: 一共有n次操作,每次操作只有成功与失败之分,成功对应1,失败对应0,n次操作对应为1 ...
- BZOJ 4318 OSU! ——期望DP
这次要求$x^3$的概率和. 直接维护三个值$x$ $x^2$ $x^3$的期望. 概率的平方不等于平方的概率. #include <map> #include <ctime> ...
- BZOJ 4318 OSU!(概率DP)
题意 osu 是一款群众喜闻乐见的休闲软件. 我们可以把osu的规则简化与改编成以下的样子: 一共有n次操作,每次操作只有成功与失败之分,成功对应1,失败对应0,n次操作对应为1个长度为n的01串.在 ...
- BZOJ 4318: OSU! 期望概率dp && 【BZOJ3450】【Tyvj1952】Easy 概率DP
这两道题是一样的...... 我就说一下较难的那个 OSU!: 这道15行的水题我竟然做了两节课...... 若是f[i][0]=(1-p)*f[i-1][0]+(1-p)*f[i-1][1],f[i ...
- BZOJ 4318: OSU! [DP 概率]
传送门 题意:变成了告诉每个操作的成功概率,并且得分是三次方 一样....分别维护$x,\ x^2,\ x^3$的期望就行了 注意$x^3$是我们最终求的得分,即使失败得分也要累加上之前的 #incl ...
- bzoj 4318 OSU! - 动态规划 - 概率与期望
Description osu 是一款群众喜闻乐见的休闲软件. 我们可以把osu的规则简化与改编成以下的样子: 一共有n次操作,每次操作只有成功与失败之分,成功对应1,失败对应0,n次操作对应为1 ...
随机推荐
- Redis 常用命令学习二:字符串类型命令
1.赋值与取值命令 127.0.0.1:6379> set foo helloredis OK 127.0.0.1:6379> get foo "helloredis" ...
- oracle经典查询语句
1. select * from emp; 2. select empno, ename, job from emp; 3. select empno 编号, ename 姓名, job 工作 ...
- Linux (x86) Exploit 开发系列教程之一(典型的基于堆栈的缓冲区溢出)
(1)漏洞代码 //vuln.c #include <stdio.h> #include <string.h> int main(int argc, char* argv[]) ...
- python之SQLite笔记
sqlite3 打开文件并创建游标 conn = sqlite3.connect('adressbook.db')c = conn.cursor() 连接对象:sqlite3.connect('数据文 ...
- 强类型c语言 类型
C 语言是一门强类型的语言,类型决定语言的特性,允许在相同类型进行运算. *强类型语言的特点: 1 先声明,后使用. 2 类型不可变. * 基本数据类型 * 数据类型的范 ...
- 使用Canvas压缩图片
讲干货,不啰嗦,当涉及对图片有质量压缩要求的时候,可以使用Canvas实现图片压缩. 步骤: 1.获取img元素,既要压缩的图片 2.创建canvas对象 3.使用canvas的drawImage方法 ...
- vue在axios中 this 指向问题
1.解决办法 在vue中使用axios做网络请求的时候,会遇到this不指向vue,而为undefined,可以使用箭头函数"=>"来解决.如下: methods: { lo ...
- YAPI安装和使用
.本人已验证,参考文档:https://blog.csdn.net/qq_39429962/article/details/84000460 很详细.
- Java 面向对象(六)接口
一.接口 接口:是Java语言中一种引用类型,是方法的集合,如果说类的内部封装了成员变量.构造方法和成员方法,那么接口的内部主要就是封装了方法,包含抽象方法(JDK 7及以前),默认方法和静态方法(J ...
- Spring Boot 实现热部署
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring- ...