HDU 2955
来源:互联网 发布:qq邮箱smtp服务器端口 编辑:程序博客网 时间:2024/06/06 05:02
又开始练DP了,= =!,没办法 ,新组的队友也是DP弱鸡,只能开始练习了。
此题看完后就是一个01背包,一开始想到是如果把背包容量当成概率,然后能抢到的前当成价值,然后一开始就把概率乘以1000000后化成int,再进行01背包,其实这一开始就是错误的了,这个题的概率当抢了两个以上的银行的时候不应该是常见的01背包的那种累加的情况,而应该是累成的情况。这点需要注意下。还有就是价值应该换成不被抓概率,也就是安全概率,否则计算是不对的。
只有逃跑率才会等于各个逃跑率之积,被抓的概率不会等于各个被抓的概率之积,,概率的知识。
#include<cstdio>#include<cstring>#include<algorithm>using namespace std;typedef long long LL;int t;double P,p[150],dp[10050];int n,m[150],d[150];int main(){ scanf("%d",&t); while(t--) { memset(dp,0,sizeof(dp)); dp[0]=1; scanf("%lf%d",&P,&n); P=1-P; int maxs=0; for(int i=1;i<=n;i++) { scanf("%d%lf",&m[i],&p[i]); p[i]=1-p[i]; maxs+=m[i]; } for(int i=1;i<=n;i++) { for(int j=maxs;j>=m[i];j--) { dp[j]=max(dp[j],dp[j-m[i]]*p[i]);//概率是一个累乘的过程 } } for(int i=maxs;i>=0;i--) { if(dp[i]-P>0.00000001) { printf("%d\n",i); break; } } } return 0;}
0 0
- hdu 2955
- HDU 2955
- HDU 2955
- HDU 2955
- hdu 2955
- hdu 2955
- hdu 2955
- hdu 2955
- hdu 2955
- HDU--2955
- hdu 2955
- HDU 2955
- HDU 2955
- HDU 2955
- hdu 2955
- hdu--2955
- HDU 2955
- hdu 2955
- hadoop系列-linux及hadoop、hdfs、hive、hbase常用命令
- STL hash_map使用
- 第六章 访问权限控制
- Android ViewPager的使用方法
- BIOS/UEFI基础——EFI_HANDLE
- HDU 2955
- 明白了一些关于命名空间(using space)的小东西
- Java中的对称加密算法
- lcd——51程序
- 行人检测开题报告
- 80端口被NT kernel & System 占用pid 4
- 数字三角形_递归_递推(动态规划)
- 2015 ICPC长春赛区铜牌题
- OpenCV13(摄像机显示和图像捕获 + 控制台下获取时间)