【Link】:http://acm.hdu.edu.cn/showproblem.php?pid=4649

【Description】



给你一个由位运算“与”“或”“和”组成的计算表达式;

每个运算符都有p[i]的几率消失;

问你最后这个计算表达式的值的期望是多少?

运算的数字< 220

【Solution】



因为二进制在进行位运算的时候,是不会产生进位的;

因此,我们可以一位一位地算;

即从二进制的第一位开始算,通过一个简单的DP,得到

这一位在n个数字做完之后为1的概率是多少;

然后乘上2^0即可;

对于第二位,第三位…用同样的方法做即可;

定义的状态为

f[i][j][k]表示第i位,在前j个数算完之后,为k的概率是多少,k=0或者1;



【NumberOf WA】



0



【Reviw】



二进制在计算的时候,不会产生进位->各个位的计算是独立的;

这里利用了一个独立的思想;



【Code】

#include <bits/stdc++.h>
using namespace std;
#define int long long
using namespace std; const int M = 20;
const int N = 200; double f[M+10][N+10][2],p[N+10],ans = 0;
int two[M+10],n,a[N+10];
char s[N+10][5]; main(){
//freopen("/home/ccy/rush.txt","r",stdin);
two[0] = 1;
for (int i = 1;i <= M;i++)
two[i] = two[i-1]*2;
int kk = 0;
while(~scanf("%lld",&n)){
ans = 0;
for (int i = 1;i <= n+1;i++)
scanf("%lld",&a[i]);
for (int i = 1;i <= n;i++)
scanf("%s",s[i]);
for (int i = 1;i <= n;i++)
scanf("%lf",&p[i]);
for (int i = 0;i <= M-1;i++){
int temp = two[i];
if (a[1]&temp)
f[i][1][1] = 1,f[i][1][0] = 0;
else
f[i][1][0] = 1,f[i][1][1] = 0;
for (int j = 1;j <= n;j++){
if (a[j+1]&temp){
if (s[j][0]=='&'){
f[i][j+1][1] = f[i][j][1];
f[i][j+1][0] = f[i][j][0];
}
if (s[j][0]=='|'){
f[i][j+1][1] = f[i][j][1] + f[i][j][0]*(1-p[j]);
f[i][j+1][0] = f[i][j][0]*p[j];
}
if (s[j][0]=='^'){
f[i][j+1][1] = f[i][j][0]*(1-p[j]) + f[i][j][1]*p[j];
f[i][j+1][0] = f[i][j][1]*(1-p[j]) + f[i][j][0]*p[j];
}
}else{
//(a[j+1]&temp)==0
//a[j+1] in i == 0
if (s[j][0]=='&'){
f[i][j+1][1] = f[i][j][1]*p[j];
f[i][j+1][0] = f[i][j][0] + f[i][j][1]*(1-p[j]);
}
if (s[j][0]=='|'){
f[i][j+1][1] = f[i][j][1];
f[i][j+1][0] = f[i][j][0];
}
if (s[j][0]=='^'){
f[i][j+1][1] = f[i][j][1];
f[i][j+1][0] = f[i][j][0];
}
}
}
ans = ans + 1.0*temp*f[i][n+1][1];
}
printf("Case %lld:\n%.6lf\n",++kk,ans);
}
return 0;
}

【hdu 4696】Professor Tian的更多相关文章

  1. 【数位dp】【HDU 3555】【HDU 2089】数位DP入门题

    [HDU  3555]原题直通车: 代码: // 31MS 900K 909 B G++ #include<iostream> #include<cstdio> #includ ...

  2. 【HDU 5647】DZY Loves Connecting(树DP)

    pid=5647">[HDU 5647]DZY Loves Connecting(树DP) DZY Loves Connecting Time Limit: 4000/2000 MS ...

  3. -【线性基】【BZOJ 2460】【BZOJ 2115】【HDU 3949】

    [把三道我做过的线性基题目放在一起总结一下,代码都挺简单,主要就是贪心思想和异或的高斯消元] [然后把网上的讲解归纳一下] 1.线性基: 若干数的线性基是一组数a1,a2,a3...an,其中ax的最 ...

  4. 【HDU 2196】 Computer(树的直径)

    [HDU 2196] Computer(树的直径) 题链http://acm.hdu.edu.cn/showproblem.php?pid=2196 这题可以用树形DP解决,自然也可以用最直观的方法解 ...

  5. 【HDU 2196】 Computer (树形DP)

    [HDU 2196] Computer 题链http://acm.hdu.edu.cn/showproblem.php?pid=2196 刘汝佳<算法竞赛入门经典>P282页留下了这个问题 ...

  6. 【HDU 5145】 NPY and girls(组合+莫队)

    pid=5145">[HDU 5145] NPY and girls(组合+莫队) NPY and girls Time Limit: 8000/4000 MS (Java/Other ...

  7. 【hdu 1043】Eight

    [题目链接]:http://acm.hdu.edu.cn/showproblem.php?pid=1043 [题意] 会给你很多组数据; 让你输出这组数据到目标状态的具体步骤; [题解] 从12345 ...

  8. 【HDU 3068】 最长回文

    [题目链接] http://acm.hdu.edu.cn/showproblem.php?pid=3068 [算法] Manacher算法求最长回文子串 [代码] #include<bits/s ...

  9. 【HDU 4699】 Editor

    [题目链接] http://acm.hdu.edu.cn/showproblem.php?pid=4699 [算法] 维护两个栈,一个栈放光标之前的数,另外一个放光标之后的数 在维护栈的同时求最大前缀 ...

随机推荐

  1. 二叉查找树BST 模板

    二叉查找树BST 就是二叉搜索树 二叉排序树. 就是满足 左儿子<父节点<右儿子 的一颗树,插入和查询复杂度最好情况都是logN的,写起来很简单.   根据BST的性质可以很好的解决这些东 ...

  2. P3514 [POI2011]LIZ-Lollipop(规律+瞎搞)

    题意 给一个只有1和2的序列,每次询问有没有一个子串的和为x ( 1≤n,m≤1 000 000 )kkk ( 1≤k≤2 000 000 ) 题解 我觉得是道好题. 主要是证明一个性质:假如有一个字 ...

  3. Hexo Next 调优

    Links对齐 编辑themes/next/source/css/_custom下的custom.styl,添加如下代码即可. .links-of-blogroll-title{ margin-lef ...

  4. Linux下的压缩与解压缩

    1 .gz 1)压缩 root@xiaohuang-virtual-machine:/home/xiaohuang/桌面/hellow/hellow# gzip 2.txt 3.txt root@xi ...

  5. P1872 回文串计数(回文树)

    题目描述 小a虽然是一名理科生,但他常常称自己是一名真正的文科生.不知为何,他对于背诵总有一种莫名其妙的热爱,这也促使他走向了以记忆量大而闻名的生物竞赛.然而,他很快发现这并不能满足他热爱背诵的心,但 ...

  6. 玩具(toy)

    题目 试题2:玩具(toy) 源代码:toy.cpp 输入文件:toy.in 输出文件:toy.out 时间限制:1s 空间限制:256MB 题目描述 商店正在出售小C最喜欢的系列玩具,在接下来的n周 ...

  7. 深入理解Struts2

    简单介绍 Struts 2是Struts的下一代产品.是在 struts 1和WebWork的技术基础上进行了合并的全新的Struts 2框架. 其全新的Struts 2的体系结构与Struts 1的 ...

  8. session和cookie详解

    摘要:虽然session机制在web应用程序中被采用已经很长时间了,但是仍然有很多人不清楚session机制的本质,以至不能正确的应用这一 技术.本文将详细讨论session的工作机制并且对在Java ...

  9. ES6学习笔记(二)变量的解构与赋值

    1.数组的解构赋值 1.1基本用法 ES6 允许按照一定模式,从数组和对象中提取值,对变量进行赋值,这被称为解构(Destructuring). 以前,为变量赋值,只能直接指定值. let a = 1 ...

  10. IBM将收购Linux发行商红帽公司,继续发力云计算市场

    10月29日凌晨消息,IBM和Red Hat当地时间星期日联合宣布,IBM将以340亿美元收购红帽公司(Red Hat).根据两家公司发表的一份联合声明,IBM将以每股190美元的价格,以现金方式收购 ...