不超过 1000 的正整数 N 表示月饼的种类数、以及不超过 500(以万吨为单位)的正整数 D 表示市场最大需求量。随后一行给出 N 个正数表示每种月饼的库存量(以万吨为单位);最后一行给出 N 个正数表示每种月饼的总售价(以亿元为单位)。数字间以空格分隔。
输出格式:
对每组测试用例,在一行中输出最大收益,以亿元为单位并精确到小数点后 2 位。
输入样例:
3 20
18 15 10
75 72 45
输出样例:
94.50
作者
陈越
单位
浙江大学
代码长度限制
16 KB
时间限制
150 ms
内存限制
64 MB
#include<iostream>
#include<algorithm>
#include<iomanip>
using namespace std;
#define max 1000
struct mooncake{
int no;
double sto;
double price;
double p;
};
mooncake mc[max];
bool cmp(mooncake a,mooncake b){
return a.p>=b.p;
};
double greedy(int n,double need){
double value;
value=0;
for(int i=0;i<n;i++){
if(need>=mc[i].sto){
value=value+mc[i].price;
need=need-mc[i].sto;
}
else{
value=value+need/mc[i].sto*mc[i].price;
need=need-mc[i].sto;
break;
}
}
return value;
}
int main(){
int n;
int need;
cin>>n
>>need;
for(int i=0;i<n;i++){
cin>> mc[i].sto;
}
for(int i=0;i<n;i++){
cin>>mc[i].price;
mc[i].p=mc[i].price/mc[i].sto;
}
sort(mc,mc+n,cmp);
printf("%.2f\n",greedy(n,need));
return 0;
}