月餅是中國(guó)人在中秋佳節(jié)時(shí)吃的一種傳統(tǒng)食品,不同地區(qū)有許多不同風(fēng)味的月餅?,F(xiàn)給定所有種類(lèi)月餅的庫(kù)存量、總售價(jià)、以及市場(chǎng)的最大需求量,請(qǐng)你計(jì)算可以獲得的最大收益是多少。
注意:銷(xiāo)售時(shí)允許取出一部分庫(kù)存。樣例給出的情形是這樣的:假如我們有3種月餅,其庫(kù)存量分別為18、15、10萬(wàn)噸,總售價(jià)分別為75、72、45億元。如果市場(chǎng)的最大需求量只有20萬(wàn)噸,那么我們最大收益策略應(yīng)該是賣(mài)出全部15萬(wàn)噸第2種月餅、以及5萬(wàn)噸第3種月餅,獲得 72 + 45/2 = 94.5(億元)。
輸入格式:
每個(gè)輸入包含1個(gè)測(cè)試用例。每個(gè)測(cè)試用例先給出一個(gè)不超過(guò)1000的正整數(shù)N表示月餅的種類(lèi)數(shù)、以及不超過(guò)500(以萬(wàn)噸為單位)的正整數(shù)D表示市場(chǎng)最大需求量。隨后一行給出N個(gè)正數(shù)表示每種月餅的庫(kù)存量(以萬(wàn)噸為單位);最后一行給出N個(gè)正數(shù)表示每種月餅的總售價(jià)(以?xún)|元為單位)。數(shù)字間以空格分隔。
輸出格式:
對(duì)每組測(cè)試用例,在一行中輸出最大收益,以?xún)|元為單位并精確到小數(shù)點(diǎn)后2位。
#include<iostream>
#include<algorithm>
#include <vector>
using namespace std;
struct H
{
double cun;//庫(kù)存
double mon;//總售價(jià)
double s;//單價(jià)
};
bool compare(H a,H b)
{
return a.s>b.s;
}
int main()
{
int kind,n;
cin>>kind>>n;
vector<H> array(n);
for(int i=0;i<kind;i++)
{
cin>>array[i].cun;
}
for(int i=0;i<kind;i++)
{
cin>>array[i].mon;
}
for(int i=0;i<kind;i++)
{
array[i].s=array[i].mon/array[i].cun;
}
sort(array.begin(),array.end(),compare);
int term=0;
double sum=0;
for(int i=0;i<kind &&term!=n;i++)
{
if((n-term)>=array[i].cun)
{
term+=array[i].cun;
sum+=array[i].mon;
}
else
{
sum+=(n-term)*array[i].s;
term=n;
}
}
printf("%.2f",sum);
return 0;
}
運(yùn)行時(shí)可以的,但提交說(shuō)是有異常退出,唔。
所以參考
#include <iostream>
#include <stdlib.h>
using namespace std;
int compare(const void *a_t, const void *b_t){
double *a = (double *)a_t, *b = (double *)b_t;
return b[2] > a[2];
}
int main(){
int type, max;
scanf("%d %d", &type, &max);
double moonCake[type][3]; //行數(shù)一會(huì)換成type,n行三列,分別是庫(kù)存量、總售價(jià)、單價(jià)
for(int i = 0; i < 2; ++i){
for(int j = 0; j < type; ++j){
scanf("%lf", &moonCake[j][i]);
}
}
for(int l = 0; l < type; ++l){
moonCake[l][2] = moonCake[l][1] / moonCake[l][0];
}
qsort(&moonCake[0], type, sizeof(moonCake[0]), compare);
double profit = 0;
double tmp = max;
for(int k = 0; k < type && tmp != 0; ++k){
if(moonCake[k][0] <= tmp){
profit += moonCake[k][1];
tmp -= moonCake[k][0];
}
else{
profit += (moonCake[k][2] * tmp);
tmp = 0;
}
}
printf("%.2f\n", profit);
return 0;
}```
作者:FlyRush
鏈接:http://www.itdecent.cn/p/ba3e95d9c72b
來(lái)源:簡(jiǎn)書(shū)
著作權(quán)歸作者所有。商業(yè)轉(zhuǎn)載請(qǐng)聯(lián)系作者獲得授權(quán),非商業(yè)轉(zhuǎn)載請(qǐng)注明出處。