bzoj3450 Easy(概率期望dp)
3450: Tyvj1952 Easy
Time Limit: 10 Sec  Memory Limit: 128 MB
Submit: 876  Solved: 648
[Submit][Status][Discuss]
Description
某一天WJMZBMR在打osu~~~但是他太弱逼了,有些地方完全靠运气:(
我们来简化一下这个游戏的规则
有n次点击要做,成功了就是o,失败了就是x,分数是按comb计算的,连续a个comb就有a*a分,comb就是极大的连续o。
比如ooxxxxooooxxx,分数就是2*2+4*4=4+16=20。
Sevenkplus闲的慌就看他打了一盘,有些地方跟运气无关要么是o要么是x,有些地方o或者x各有50%的可能性,用?号来表示。
比如oo?xx就是一个可能的输入。
那么WJMZBMR这场osu的期望得分是多少呢?
比如oo?xx的话,?是o的话就是oooxx => 9,是x的话就是ooxxx => 4
期望自然就是(4+9)/2 =6.5了
Input
第一行一个整数n,表示点击的个数
接下来一个字符串,每个字符都是ox?中的一个
Output
一行一个浮点数表示答案
四舍五入到小数点后4位
如果害怕精度跪建议用long double或者extended
Sample Input
????
Sample Output
n<=300000
osu很好玩的哦
WJMZBMR技术还行(雾),x基本上很少呢
HINT
Source
/*
f[i]表示到第i位的得分期望
L[i]表示已i结尾的长度期望
可知如果是o:L[i]=L[i-1]+1 由(L+1)^2=L^2+2*L+1可得 f[i]=f[i-1]+2*L[i-1]+1
如果是x:f[i]=f[i-1],L[i]=0;
如果是?:L[i]=(L[i-1]+1)/2 f[i]=(2*f[i-1]+2*L[i-1]+1)/2;
*/
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath> #define N 300007 using namespace std;
int n,m,k,cnt;
double ans,f[N],L[N];
char s[N],ch[N]; int main()
{
scanf("%d",&n);scanf("%s",s+);
f[]=;n=strlen(s+);
for(int i=;i<=n;i++)
{
if(s[i]=='o') L[i]=L[i-]+,f[i]=f[i-]+*L[i-]+;
else if(s[i]=='x') f[i]=f[i-];
else if(s[i]=='?') L[i]=(L[i-]+1.0)/2.0,f[i]=f[i-]+L[i-]+0.5;
}
printf("%.4lf\n",f[n]);
return ;
}
bzoj3450 Easy(概率期望dp)的更多相关文章
- 【BZOJ-1419】Red is good     概率期望DP
		
1419: Red is good Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 660 Solved: 257[Submit][Status][Di ...
 - 【bzoj4832】[Lydsy2017年4月月赛]抵制克苏恩  概率期望dp
		
题目描述 你分别有a.b.c个血量为1.2.3的奴隶主,假设英雄血量无限,问:如果对面下出一个K点攻击力的克苏恩,你的英雄期望会受到到多少伤害. 输入 输入包含多局游戏. 第一行包含一个整数 T (T ...
 - 【loj6191】「美团 CodeM 复赛」配对游戏  概率期望dp
		
题目描述 n次向一个栈中加入0或1中随机1个,如果一次加入0时栈顶元素为1,则将这两个元素弹栈.问最终栈中元素个数的期望是多少. 输入 一行一个正整数 n . 输出 一行一个实数,表示期望剩下的人数, ...
 - Codeforces - 1264C - Beautiful Mirrors with queries - 概率期望dp
		
一道挺难的概率期望dp,花了很长时间才学会div2的E怎么做,但这道题是另一种设法. https://codeforces.com/contest/1264/problem/C 要设为 \(dp_i\ ...
 - 概率期望dp
		
对于概率dp,我一直都弄得不是特别明白,虽然以前也有为了考试去突击过,但是终究还是掌握得不是很好,所以决定再去学习一遍,把重要的东西记录下来. 1.hdu4405 Description 在一个 \( ...
 - Codeforces 908 D.New Year and Arbitrary Arrangement (概率&期望DP)
		
题目链接:New Year and Arbitrary Arrangement 题意: 有一个ab字符串,初始为空. 用Pa/(Pa+Pb)的概率在末尾添加字母a,有 Pb/(Pa+Pb)的概率在末尾 ...
 - [BZOJ4832]抵制克苏恩(概率期望DP)
		
方法一:倒推,最常规的期望DP.f[i][a][b][c]表示还要再攻击k次,目前三种随从个数分别为a,b,c的期望攻击英雄次数,直接转移即可. #include<cstdio> #inc ...
 - LightOJ 1030 Discovering Gold (概率/期望DP)
		
题目链接:LightOJ - 1030 Description You are in a cave, a long cave! The cave can be represented by a \(1 ...
 - 2018.08.30 Tyvj1952 Easy(期望dp)
		
Description 某一天WJMZBMR在打osu~~~但是他太弱逼了,有些地方完全靠运气:( 我们来简化一下这个游戏的规则 有n次点击要做,成功了就是o,失败了就是x,分数是按comb计算的,连 ...
 
随机推荐
- Django——配置服务器上线
			
使用UWSGI和NGINX配置项目上线 首先你得有一个拿得出手的项目 其次,购买了域名,也备案成功了 将settings.py中的DEBUG设置为False 配置Uwsgi 在项目(哪里都可以)中创建 ...
 - centos相关
			
查看虚拟机里的Centos7的IP:ip addr或者ifconfig ---https://blog.csdn.net/dancheren/article/details/73611878 Cen ...
 - Leetcode 188.买卖股票的最佳时机IV
			
买卖股票的最佳时机IV 给定一个数组,它的第 i 个元素是一支给定的股票在第 i 天的价格. 设计一个算法来计算你所能获取的最大利润.你最多可以完成 k 笔交易. 注意: 你不能同时参与多笔交易(你必 ...
 - 数位dp  3943   二分法
			
转载:http://blog.csdn.net/wdcjdtc/article/details/39177905 #include"cstdlib" #include"c ...
 - Thinkphp5.0 的视图view的循环标签
			
Thinkphp5.0 的视图view的循环标签 volist标签: <!-- 使用volist --> <!-- name是传递过来的要循环变量名 --> <!-- k ...
 - java代码判断文件类型(判断文件后缀名)
			
1.两点需要注意 1.string.spilt("\\.")分割字符串成子字符串数组,以“.”分割,必须写成string.spilt("\\.")的方式,不能写 ...
 - 如何探测浏览器是否开启js功能
			
<body> ... ... <script type="text/javascript"> <!-- document.write("He ...
 - springmvc 中model中放入枚举类型
			
我们直接看样例: Map<String, String> mallMap = new HashMap<String, String>(); mallMap.put(MallSt ...
 - 踩坑录-libreoffice fatal error com.sun.start.ucb.Interactive.AugmentedIOException: a folder could not be created
			
错误概要: 1.LibreOffice可以正常使用: 2.启动tomcat报错如下: Fatal error The application cannot be started. ][context= ...
 - jQuery异步框架探究1:jQuery._Deferred方法
			
jQuery异步框架应用于jQuery数据缓存模块.jQuery ajax模块.jQuery事件绑定模块等多个模块,是jQuery的基础功能之中的一个.实际上jQuery实现的异步回调机制能够看做ja ...