商人的訣竅

2021-08-17 04:35:01 字數 1347 閱讀 2264

商人的訣竅

time limit: 1000 ms memory limit: 65536 kib

submit statistic discuss

problem description

e_star和von是中國赫赫有名的兩位商人,俗話說的好無商不奸,最近e_star需要進一批蘋果。可是他需要的蘋果只有von才有,von的蘋果都存在他的傳說中很牛叉的倉庫裡,每個倉庫都存了不同種類的蘋果,而且每個倉庫裡的蘋果的價錢不同。如果e_star想要買倉庫i裡的所有重量為f[i]的蘋果他必須付m[i]的金錢。e_star開著他的傳說中的毛驢車去拉蘋果,而且他只帶了n些金錢。e_star作為傳說中的奸商希望用它所帶的n金錢得到重量最多的蘋果。你作為他最好的朋友,所以他向你求出幫助。希望你能幫忙計算出他能買到最多的蘋果(這裡指重量最大)。並輸出最大重量。

input

第一行包括兩個非負整數n,m(分別代表e_star帶的金幣數,von盛蘋果的倉庫數量,不超過50)。

接下來有有m行,每行包括兩個數非負整數f[i]和m[i]分別表示第i倉庫裡存有重量為f[i]的蘋果,如果將所有蘋果買下要花費m[i]的金錢,e_star不必非要將每個倉庫的蘋果全部買下。

當m,n同時為-1是結束。

output

e_star用n的金幣所能買到的最大重量的蘋果的重量。結果保留三位小數。

sample input

5 3

7 2

4 3

5 2

20 3

25 18

24 15

15 10

-1 -1

sample output

13.333

31.500

hint

source

note:需要注意的點是排序排的是單價,而不是單純的重量,單價拍完序之後先看自己的金錢是不是比某個倉庫裡的總錢數要多,買下這個倉庫的所有後,在按照單價去買所需的貨物

**:

#include

#include

struct node

a[51];

void arrange(struct node a,int left,int right);

int main()

arrange(a,1,m);

double k=0;int i=1;

while(n)

else

}else

break;

}printf("%.3lf\n",k);

}return0;}

void arrange(struct node a,int left,int right)

商人的訣竅

輸入 第一行包括兩個非負整數n,m 分別代表e star帶的金幣數,von盛蘋果的倉庫數量,不超過50 接下來有有m行,每行包括兩個數非負整數f i 和m i 分別表示第i倉庫裡存有重量為f i 的蘋果,如果將所有蘋果買下要花費m i 的金錢,e star不必非要將每個倉庫的蘋果全部買下。當m,n同...

商人的訣竅

problem description e star和von是中國赫赫有名的兩位商人,俗話說的好無商不奸,最近e star需要進一批蘋果。可是他需要的蘋果只有von才有,von的蘋果都存在他的傳說中很牛叉的倉庫裡,每個倉庫都存了不同種類的蘋果,而且每個倉庫裡的蘋果的價錢不同。如果e star想要買倉...

商人的訣竅

problem description e star和von是中國赫赫有名的兩位商人,俗話說的好無商不奸,最近e star需要進一批蘋果。可是他需要的蘋果只有von才有,von的蘋果都存在他的傳說中很牛叉的倉庫裡,每個倉庫都存了不同種類的蘋果,而且每個倉庫裡的蘋果的價錢不同。如果e star想要買倉...