hdu 1203 I NEED A OFFER! 01背包
2014-08-04 19:53
531 查看
题目传送门 http://acm.hdu.edu.cn/showproblem.php?pid=1203
中文题 就不用解释题意了吧
这是简单的01背包 跟以往不同的是这个说是让求 最大可能性的 但规划的时候要找最小值,求全部学校都不要他的概率的最小值,
一样例为例 ,44.0%是这样来的1-(1-0.3)(1-0.2)=0.44; 所以我们要规划出减数的最小值;
代码………………………………………………………………………………………………………………
#include<stdio.h>
#include<string.h>
#include<algorithm>
using namespace std;
double bi[10010],dp[10010];
int ai[10010];
int main()
{
int V,n;
while(scanf("%d%d",&V,&n),V||n)
{
int i,j;
memset(dp,0,sizeof(dp));
for(i=0;i<=V;i++)
dp[i]=1.0;
for( i=0;i<n;i++)
{
scanf("%d%lf",&ai[i],&bi[i]);
}
for(i=0;i<n;i++)
{
for(j=V;j>=ai[i];j--)
dp[j]=min(dp[j],(1-bi[i])*dp[j-ai[i]]);
}
printf("%.1lf%%\n",(1-dp[V])*100);
}
}
中文题 就不用解释题意了吧
这是简单的01背包 跟以往不同的是这个说是让求 最大可能性的 但规划的时候要找最小值,求全部学校都不要他的概率的最小值,
一样例为例 ,44.0%是这样来的1-(1-0.3)(1-0.2)=0.44; 所以我们要规划出减数的最小值;
代码………………………………………………………………………………………………………………
#include<stdio.h>
#include<string.h>
#include<algorithm>
using namespace std;
double bi[10010],dp[10010];
int ai[10010];
int main()
{
int V,n;
while(scanf("%d%d",&V,&n),V||n)
{
int i,j;
memset(dp,0,sizeof(dp));
for(i=0;i<=V;i++)
dp[i]=1.0;
for( i=0;i<n;i++)
{
scanf("%d%lf",&ai[i],&bi[i]);
}
for(i=0;i<n;i++)
{
for(j=V;j>=ai[i];j--)
dp[j]=min(dp[j],(1-bi[i])*dp[j-ai[i]]);
}
printf("%.1lf%%\n",(1-dp[V])*100);
}
}
相关文章推荐
- HDU 1203 I NEED A OFFER! 01背包题解
- 【HDU 1203】I NEED A OFFER!(01背包)
- HDU1203 I NEED A OFFER! 01背包 概率
- hdu1203 I NEED A OFFER!(01背包)
- hdu 1203 I NEED A OFFER!(简单01背包)
- HDU 1203 I NEED A OFFER!【01背包】
- HDU 1203 I NEED A OFFER!(01背包)
- HDU 1203 I NEED A OFFER!【01背包】
- hdu 1203 I NEED A OFFER!(01背包)
- HDU 1203 I NEED A OFFER!(01背包)
- HDU - 1203 I NEED A OFFER!(01背包)
- HDU 1203 I NEED A OFFER!【01背包】
- HDU 2955 Robberies 和 HDU 1203 I NEED A OFFER!【思维转化 + 01背包】好题 !!!
- HDU 1203 I NEED A OFFER! 简单01背包问题
- hdu 1203 I NEED A OFFER!(01背包)
- hdu 1203 I NEED A OFFER!(01背包)
- 【HDU - 1203 】 I NEED A OFFER! 【01背包】
- hdu 1203 I NEED A OFFER!(01背包,%%输出%符号)
- HDU 1203 I NEED A OFFER!(01背包)
- hdu 1203 I NEED A OFFER!(01背包)