152 - Expected value of the expression

Time Limit:2s Memory Limit:128MByte

Submissions:135Solved:65

DESCRIPTION

You are given an expression: A0O1A1O2A2⋯OnAnA0O1A1O2A2⋯OnAn, where Ai(0≤i≤n)Ai(0≤i≤n) represents number, Oi(1≤i≤n)Oi(1≤i≤n) represents operator. There are three operators, &,|,^&,|,^, which means and,or,xorand,or,xor, and they have the same priority.

The ii-th operator OiOi and the numbers AiAi disappear with the probability of pipi.

Find the expected value of an expression.

INPUT
The first line contains only one integer n(1≤n≤1000)n(1≤n≤1000). The second line contains n+1n+1 integers Ai(0≤Ai<220)Ai(0≤Ai<220). The third line contains nn chars OiOi. The fourth line contains nn floats pi(0≤pi≤1)pi(0≤pi≤1).
OUTPUT
Output the excepted value of the expression, round to 6 decimal places.
SAMPLE INPUT
2
1 2 3
^ &
0.1 0.2
SAMPLE OUTPUT
2.800000
HINT
Probability = 0.1 * 0.2 Value = 1 Probability = 0.1 * 0.8 Value = 1 & 3 = 1
Probability = 0.9 * 0.2 Value = 1 ^ 2 = 3
Probability = 0.9 * 0.8 Value = 1 ^ 2 & 3 = 3
Expected Value = 0.1 * 0.2 * 1 + 0.1 * 0.8 * 1 + 0.9 * 0.2 * 3 + 0.9 * 0.8 * 3 = 2.80000
疏于补题,在这种学习环境下我也很难进步,要想做的足够优秀,本来就是要花时间和别人不一样啊
想下前两天有人讲状压dp,讲完那道题我应该会做了,因为我做过状压dp的题,但是换一道一定是不一定的啊,但是我觉得作为一个讲解者,我会倾向于向大家普及更多的知识,从而共同进步
闲话还是少说好了,等觉得真的有些难受的话就写些鸡汤,鼓励下正在努力的自己
概率dp,往常也和期望有关,什么是期望呢,饿了么霸王餐30个人付30元抽到20元的红包,我投资1元红包中奖期望是0.67元,这明摆着就是亏得生意啊,但是赌徒心理会致使我买下去,其实中奖了并不意味着省钱,往常中奖了就有会去吃顿好的
也就是所得分数*概率,把所有的可能都累城下,这个内容是高中学的,但是我可不可以合并同类项啊

E=(Σp1*(E1+X1)+Σp2*X2)/(1-Σp2)得到这样一个通项公式,这样能在中间就对数据进行处理

给你一个n+1个数进行n个位操作和他们出现的概率,求下这个表达式的期望

再结合这个题目的意思和运算符的一些问题,进行状态转移就好了

#include<bits/stdc++.h>
using namespace std;
int a[];
int num[];
char op[][];
double p[];
double dp[][];
int main()
{
int n;
while(~scanf("%d",&n))
{
for(int i=; i<=n; i++)scanf("%d",&num[i]);
for(int i=; i<=n; i++)scanf("%s",op[i]);
for(int i=; i<=n; i++)scanf("%lf",&p[i]);
double ans=;
for(int i=; i<=; i++)
{
for(int j=; j<=n; j++)
{
if((num[j]&(<<i))>)
{
a[j]=;
}
else a[j]=;
}
memset(dp,,sizeof(dp));
dp[][a[]]=;
for(int j=; j<=n; j++)
{
dp[j][]=dp[j-][]*p[j];
dp[j][]=dp[j-][]*p[j];
if(op[j][]=='|')
{
dp[j][^a[j]]+=dp[j-][]*(-p[j]);
dp[j][]+=dp[j-][]*(-p[j]);
}
else if(op[j][]=='&')
{
dp[j][]+=dp[j-][]*(-p[j]);
dp[j][^a[j]]+=dp[j-][]*(-p[j]);
}
else
{
dp[j][]+=dp[j-][^a[j]]*(-p[j]);
dp[j][]+=dp[j-][a[j]^]*(-p[j]);
}
}
ans+=(dp[n][]*(<<i));
}
printf("%.6f\n",ans);
}
return ;
}

dp好题 玲珑杯 Expected value of the expression的更多相关文章

  1. 13年山东省赛 The number of steps(概率dp水题)

    转载请注明出处: http://www.cnblogs.com/fraud/          ——by fraud The number of steps Time Limit: 1 Sec  Me ...

  2. ACM :漫漫上学路 -DP -水题

    CSU 1772 漫漫上学路 Time Limit: 1000MS   Memory Limit: 131072KB   64bit IO Format: %lld & %llu Submit ...

  3. [poj2247] Humble Numbers (DP水题)

    DP 水题 Description A number whose only prime factors are 2,3,5 or 7 is called a humble number. The se ...

  4. poj 3254 状压dp入门题

    1.poj 3254  Corn Fields    状态压缩dp入门题 2.总结:二进制实在巧妙,以前从来没想过可以这样用. 题意:n行m列,1表示肥沃,0表示贫瘠,把牛放在肥沃处,要求所有牛不能相 ...

  5. POJ 1155 TELE 背包型树形DP 经典题

    由电视台,中转站,和用户的电视组成的体系刚好是一棵树 n个节点,编号分别为1~n,1是电视台中心,2~n-m是中转站,n-m+1~n是用户,1为root 现在节点1准备转播一场比赛,已知从一个节点传送 ...

  6. 【dp入门题】【跟着14练dp吧...囧】

    A HDU_2048 数塔 dp入门题——数塔问题:求路径的最大和: 状态方程: dp[i][j] = max(dp[i+1][j], dp[i+1][j+1])+a[i][j];dp[n][j] = ...

  7. POJ 2342 树形DP入门题

    有一个大学的庆典晚会,想邀请一些在大学任职的人来參加,每一个人有自己的搞笑值,可是如今遇到一个问题就是假设两个人之间有直接的上下级关系,那么他们中仅仅能有一个来參加,求请来一部分人之后,搞笑值的最大是 ...

  8. Vijos1057 盖房子(DP经典题)

    之前没有怎么刷过dp的题,所以在此学习了~(感谢walala大神的思路,给了我很大的启发) 也算是自己学习的另一种dp题型吧 先贴上状态转移方程: if(a[i][j]) f[i][j]=min(f[ ...

  9. dp百题大过关(第一场)

    好吧,这名字真是让我想起了某段被某教科书支配的历史.....各种DP题层出不穷,不过终于做完了orz 虽然各种手糊加乱搞,但还是要总结一下. T1 Monkey Banana Problem    这 ...

随机推荐

  1. JAVA-WEB总结02

     1 什么是JavaBean?有何特征?    1)符合特定规则的类    2)JavaBean分二类: a)侠义的JavaBean .私有的字段(Field) .对私有字段提供存取方法(读写方法) ...

  2. 【Python图像特征的音乐序列生成】第一阶段的任务分配

    从即日起到7月20号,项目成员进行了第一次任务分配. 赵同学A.岳同学.周同学,负责了图像数据的情感数据集制作,他们根据自己的经验,对图像进行了情绪提取. 赵同学B全权负责向量映射这一块的网络搭建. ...

  3. Android(java)学习笔记106:Android设置文本颜色的4种方法

    1. Android设置文本颜色的4种方法: (1)利用系统自带的颜色类: tv.setTextColor(android.graphics.Color.RED); (2)数字颜色表示: tv.set ...

  4. java static block

    java 中 静态块的作用 (一)java 静态代码块 静态方法区别一般情况下,如果有些代码必须在项目启动的时候就执行的时候,需要使用静态代码块,这种代码是主动执行的;需要在项目启动的时候就初始化,在 ...

  5. JavaScript——图片懒加载

    前言 有一个朋友问我这个问题,刚好有时间,现在就简单的写个Demo~ github | https://github.com/wangyang0210/bky/tree/picLoadLazy 内容 ...

  6. cocos2dx for lua 简单的翻牌动画

    local x = 20 local y = display.height/2 for i = 1,16 do--创建16张 local cardFg = display.newSprite(&quo ...

  7. 科技庄园(背包dp)---对于蒟蒻来说死了一大片的奇题

    题目描述: Life种了一块田,里面种了一些桃树. Life对PFT说:“我给你一定的时间去摘桃,你必须在规定的时间之内回到我面前,否则你摘的桃都要归我吃!” PFT思考了一会,最终答应了! 由于PF ...

  8. poj3335 Rotating Scoreboard

    题目描述: vjudge POJ 题解: 半平面交判核的存在性. 重点在于一个点的核也算核. 这样的话普通的求多边形的版本就要加一个特判. 就是把剩下的一个节点暴力带回所有直线重判,这时判叉积是否$\ ...

  9. 初涉manacher

    一直没有打过……那么今天来找几道题打一打吧 manacher有什么用 字符串的题有一类是专门关于“回文”的.通常来说,这类问题要么和一些dp结合在一起:要么是考察对于manacher(或其他如回文自动 ...

  10. centos 安装 python3 分类链接

    上一篇文章描述了如何安装python3,但是在后续安装pip便不断报出缺少各类模块,安装一个又需要依赖另一个,导致安装过程非常繁琐.究其原因,我是安装centos-minimal版本,有许多功能不是完 ...