【hdu 4696】Professor Tian
【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的更多相关文章
- 【数位dp】【HDU 3555】【HDU 2089】数位DP入门题
[HDU 3555]原题直通车: 代码: // 31MS 900K 909 B G++ #include<iostream> #include<cstdio> #includ ...
- 【HDU 5647】DZY Loves Connecting(树DP)
pid=5647">[HDU 5647]DZY Loves Connecting(树DP) DZY Loves Connecting Time Limit: 4000/2000 MS ...
- -【线性基】【BZOJ 2460】【BZOJ 2115】【HDU 3949】
[把三道我做过的线性基题目放在一起总结一下,代码都挺简单,主要就是贪心思想和异或的高斯消元] [然后把网上的讲解归纳一下] 1.线性基: 若干数的线性基是一组数a1,a2,a3...an,其中ax的最 ...
- 【HDU 2196】 Computer(树的直径)
[HDU 2196] Computer(树的直径) 题链http://acm.hdu.edu.cn/showproblem.php?pid=2196 这题可以用树形DP解决,自然也可以用最直观的方法解 ...
- 【HDU 2196】 Computer (树形DP)
[HDU 2196] Computer 题链http://acm.hdu.edu.cn/showproblem.php?pid=2196 刘汝佳<算法竞赛入门经典>P282页留下了这个问题 ...
- 【HDU 5145】 NPY and girls(组合+莫队)
pid=5145">[HDU 5145] NPY and girls(组合+莫队) NPY and girls Time Limit: 8000/4000 MS (Java/Other ...
- 【hdu 1043】Eight
[题目链接]:http://acm.hdu.edu.cn/showproblem.php?pid=1043 [题意] 会给你很多组数据; 让你输出这组数据到目标状态的具体步骤; [题解] 从12345 ...
- 【HDU 3068】 最长回文
[题目链接] http://acm.hdu.edu.cn/showproblem.php?pid=3068 [算法] Manacher算法求最长回文子串 [代码] #include<bits/s ...
- 【HDU 4699】 Editor
[题目链接] http://acm.hdu.edu.cn/showproblem.php?pid=4699 [算法] 维护两个栈,一个栈放光标之前的数,另外一个放光标之后的数 在维护栈的同时求最大前缀 ...
随机推荐
- JDBC连接ORACLE无法登陆java.sql.SQLException: ORA-01017: invalid username/password; logon denied
当用jdbc连接Oracle数据库的时候 private Connection getConnection() throws SQLException { OracleDataSource ods = ...
- PHP实时生成并下载超大数据量的EXCEL文件
最近接到一个需求,通过选择的时间段导出对应的用户访问日志到excel中, 由于用户量较大,经常会有导出50万加数据的情况.而常用的PHPexcel包需要把所有数据拿到后才能生成excel, 在面对生成 ...
- 《2017全球人工智能人才白皮书》发布丨解读世界顶级AI牛人的秘密——腾讯研究院
<2017全球人工智能人才白皮书>发布丨解读世界顶级AI牛人的秘密——腾讯研究院:下载链接:http://www.tisi.org/c16 这个报告写的很好,排版布局,表格,色调,内容都值 ...
- 网络载入数据和解析JSON格式数据案例之空气质量监測应用
一.创建一个新的项目 activity_main.xml <LinearLayout xmlns:android="http://schemas.android.com/apk/res ...
- Objective-C学习笔记(十)——循环语句for和do-while的使用
在OC中.除了while这样的循环方式外,还有另外for循环和do-while循环.它们在不同的业务逻辑下会有不同的作用.能够和C语言和Java对照着学习. (一)代码一: int main(int ...
- Codeforces 11B Jumping Jack(数学)
B. Jumping Jack time limit per test 1 second memory limit per test 64 megabytes input standard input ...
- sp_executesql invalid object name
https://stackoverflow.com/questions/10417126/dynamically-named-temp-table-returns-invalid-object-nam ...
- thinkphp5项目--企业单车网站(五)
thinkphp5项目--企业单车网站(五) 项目地址 fry404006308/BicycleEnterpriseWebsite: Bicycle Enterprise Websitehttps:/ ...
- nyoj--38--布线问题(克鲁斯卡尔)
布线问题 时间限制:1000 ms | 内存限制:65535 KB 难度:4 描述 南阳理工学院要进行用电线路改造,现在校长要求设计师设计出一种布线方式,该布线方式需要满足以下条件: 1.把所有的 ...
- JWT 使用介绍
转载收藏于 http://www.cnblogs.com/zjutzz/p/5790180.html JWT是啥? JWT就是一个字符串,经过加密处理与校验处理的字符串,形式为: A.B.C A由JW ...