hdu 4649——Professor Tian
来源:互联网 发布:js怎么判断undefined 编辑:程序博客网 时间:2024/06/05 02:51
因为只有20位,而且&,|,^都不会进位,那么一位一位地看,每一位不是0就是1,这样求出每一位是1的概率,再乘以该位的十进制数,累加,就得到了总体的期望。
f[i][j]表示该位取前i个数,运算得到j(0或1)的概率是多少。
f[i][1]=f[i-1][1]*p[i]+根据不同运算符和第i位的值运算得到1的概率。
f[i][0]同理。
初始状态:f[0][0~1]=0或1(根据第一个数的该位来设置)
每一位为1的期望 f[n][1]
#include<iostream>#include<cstdio>using namespace std;int num[300];double p[300];char c[300];double dp[300][2];int main(){int n;int cnt=0;while(~scanf("%d",&n)){for(int i=1;i<=n+1;i++)scanf("%d",&num[i]);for(int i=2;i<=n+1;i++)cin>>c[i];for(int i=2;i<=n+1;i++)scanf("%lf",&p[i]);double ans=0.0;for(int i=1;i<=20;i++){dp[1][1]=num[1]&1;dp[1][0]=!dp[1][1];num[1]>>=1;for(int j=2;j<=n+1;j++){int k=num[j]&1;num[j]>>=1;if(c[j]=='|'){if(k==1){dp[j][1]=1*(1-p[j])+p[j]*dp[j-1][1];dp[j][0]=1-dp[j][1];}else{dp[j][1]=dp[j-1][1]*(1-p[j])+p[j]*dp[j-1][1];dp[j][0]=1-dp[j][1];}continue;}if(c[j]=='&'){if(k==1){dp[j][1]=dp[j-1][1]*(1-p[j])+p[j]*dp[j-1][1];dp[j][0]=1-dp[j][1];}else{dp[j][1]=0+p[j]*dp[j-1][1];dp[j][0]=1-dp[j][1];}continue;}if(c[j]=='^'){if(k==1){dp[j][1]=dp[j-1][0]*(1-p[j])+p[j]*dp[j-1][1];dp[j][0]=1-dp[j][1];}else{dp[j][1]=dp[j-1][1]*(1-p[j])+p[j]*dp[j-1][1];dp[j][0]=1-dp[j][1];}continue;}}ans+=(1<<(i-1))*dp[n+1][1];}printf("Case %d:\n%.6f\n",++cnt,ans);}return 0;}
- hdu 4649——Professor Tian
- hdu 4649 Professor Tian
- hdu 4649 Professor Tian
- HDU 4649 Professor Tian
- HDU 4649 Professor Tian
- hdu 4649 Professor Tian
- hdu 4649 Professor Tian (DP)
- DP hdu 4649 Professor Tian
- hdu 4649 Professor Tian(期望)
- hdu - 4649 - Professor Tian(概率dp)
- HDU 4649 - Professor Tian(概率DP)
- HDU 4649 Professor Tian (概率DP)
- HDU-4649 Professor Tian(期望dp)
- HDU 4649 Professor Tian(概率DP)
- 【HDU】4649 Professor Tian 期望DP
- HDOJ 4649 Professor Tian
- HDU 4649 Professor Tian (2013多校联合5 1007)
- hdu 4649 Professor Tian 多校第五场
- 如何设计好一款iOS游戏UI的细节
- 如何安装Ctags 和 Taglist
- CF 52C Circular RMQ(区间更新,区间询问)
- Subversion的两种工作模式
- 关于android 图像格式问题
- hdu 4649——Professor Tian
- 面试题:赛马问题
- UVA 10025 (13.08.06)
- hdu 2048 神、上帝以及老天爷
- 称球问题
- HDUOJ 4649 2013多校第五场第7题
- 给IT新人的15点建议:苦逼程序员的辛酸反省与总结
- HDU 1799 循环多少次?(排列组合,dp)
- 线性规划、梯度下降、正规方程组——斯坦福ML公开课笔记1-2