首页 > 其他 > 详细

Hdu1203

时间:2015-11-09 01:58:42      阅读:265      评论:0      收藏:0      [点我收藏+]
//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

Hdu1203

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

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