就是贪心,算出每个房间的J/F的比值,然后排序,再按性价比从高到低去取
有人提到F可能为0,这种情况也包括在内了,因为F为0时quo即为无穷大,那么必然会去先取那个无穷大性价比的房间。
代码如下:
#include <cstdio>
#include <iostream>
#include <algorithm>
#include <cstring>
using namespace std;
struct room{
int J;
int F;
double quo;
}ro[100000];
bool compare(room a,room b)
{
return a.quo>b.quo;
}
int main()
{
int M,N;
scanf("%d%d",&M,&N);
while(M!=-1||N!=-1){
memset(ro,0,sizeof(ro));
for(int i=1;i<=N;i++){
scanf("%d%d",&ro[i].J,&ro[i].F);
ro[i].quo=ro[i].J*1.0/ro[i].F;
}
sort(ro+1,ro+N+1,compare);
double sum=0.0;
for(int i=1;i<=N;i++){
if(M<=0)
break;
if(M>=ro[i].F){
sum+=ro[i].J;
M-=ro[i].F;
}
else{
sum+=M*1.0/ro[i].F*ro[i].J;
break;
}
}
printf("%.3lf\n",sum);
scanf("%d%d",&M,&N);
}
return 0;
}