首页 > 其他 > 详细

HDU 2955 Robberies dp +背包

时间:2014-10-29 23:43:00      阅读:380      评论:0      收藏:0      [点我收藏+]

题目链接~~http://acm.hdu.edu.cn/showproblem.php?pid=2955

题意 : 在不被抓住的情况下,偷的钱最多,

 

然后题目给的是被抓住的概率~ 就可以考虑在不被抓住的情况下,拿的最多的钱。。

还RT了一回    %>_<%

状态方程: dp[j]=max(dp[j],dp[j-a[i]]*p1[i]);

代码::

 1 #include <iostream>
 2 #include <cstdio>
 3 #include <cmath>
 4 using namespace std;
 5 #define max(a,b) (a>b?a:b)
 6 int main()
 7 {
 8     double p,p1[105],dp[10005];
 9     int n,a[105],t,i,j;
10     scanf("%d",&t);
11     while(t--)
12     {
13         scanf("%lf%d",&p,&n);
14         int sum=0;
15         for(i=1;i<=n;i++)
16         {
17            scanf("%d%lf",&a[i],&p1[i]);
18            p1[i]=1-p1[i];
19            sum+=a[i];
20         }
21         memset(dp,0,sizeof(dp));
22         dp[0]=1.0;
23         for(i=1;i<=n;i++)
24         {
25             for(j=sum;j>=a[i];j--)
26                dp[j]=max(dp[j],dp[j-a[i]]*p1[i]);
27         }
28         for(i=sum;i>=0;i--)
29             if(1-dp[i]<p)
30             {    
31                 printf("%d\n",i);break;
32             }
33 
34        
35     }
36   return 0;
37 }

 

HDU 2955 Robberies dp +背包

原文:http://www.cnblogs.com/caozhuang/p/4060610.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!