Hdu1203

时间:2015-11-09 01:58:42   收藏:0   阅读:266
//I NEED A OFFER!
//0/1背包
#include<stdio.h>
#include<string.h>

float min(float a,float b);

int main(){
	int  m,n,i,j,a[10005];
	float b[10005],dp[10005];
	while(scanf("%d%d",&m,&n)!=EOF&&(m||n)){
		for(i=0;i<n;i++)
		  scanf("%d%f",&a[i],&b[i]);//float %f
		for(i=0;i<10005;i++)
			dp[i]=1;
		//memset(dp,1.0,sizeof(dp));
		for(i=0;i<n;i++){
			for(j=m;j>=0;j--){
				if(j>=a[i]) dp[j]=min(dp[j],dp[j-a[i]]*(1-b[i]));//转态方程
			}
		}
		printf("%0.1f%%\n",(1-dp[m])*100);
	}
	return 0;
}
float min(float a,float b){
	return(a<b?a:b);
}


本文出自 “apple” 博客,请务必保留此出处http://22222222222.blog.51cto.com/9928498/1710734

原文:http://22222222222.blog.51cto.com/9928498/1710734

评论(0
© 2014 bubuko.com 版权所有 - 联系我们:wmxa8@hotmail.com
打开技术之扣,分享程序人生!