码迷,mamicode.com
首页 > 其他好文 > 详细

Hdu1203

时间:2015-11-09 02:01:54      阅读:255      评论: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
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!