题目链接
题解:
这个题就是怎样装才能获得最大的价值,并且糖果可以拆分。所以就可以转化为每单位糖果的价值大小,先拿价值大的,直到装满为止。
代码:
#include<iostream>
#include<stdio.h>
#include<algorithm>
using namespace std;
int n,m;
struct box
{
int v,w;
double val; //每单位的糖果价值
};
box a[101];
bool operator <(const box &x,const box &y) //重载小于号
{
return x.val<y.val;
}
int main()
{
double s=0.0;
scanf("%d%d",&n,&m);
for(int i=0;i<n;i++){
scanf("%d%d",&a[i].v,&a[i].w);
a[i].val=1.0*a[i].v/a[i].w;
}
sort(a,a+n);
for(int i=n-1;i>=0;i--){
if(m>=a[i].w){ //如果剩余的空间大于等于a[i].w就说明能全部装下
s+=a[i].v;
m-=a[i].w;
}
else{
s+=a[i].val*m; //不能全部装下就按比例装。
break;
}
}
printf("%.1lf\n",s);
return 0;
}