#P2802. 金银岛

金银岛

题目描述

某天 KID 利用飞行器飞到了一个金银岛上,上面有许多珍贵的金属。KID 虽然更喜欢各种宝石的艺术品,可也不拒绝这样珍贵的金属。但是他只带着一个口袋,口袋至多只能装重量为 ww 的物品。岛上的金属有 ss 个种类,每种金属重量不同,分别为 n1,n2,,nsn_1, n_2, \ldots, n_s,同时每个种类的金属总的价值也不同,分别为 v1,v2,,vsv_1, v_2, \ldots, v_s。KID 想一次带走价值尽可能多的金属,问他最多能带走价值多少的金属。注意金属是可以被任意分割的,并且金属的价值和其重量成正比。

输入格式

第一行是一个整数 kk,表示测试数据的组数。

每组测试数据占 33 行:

  • 11 行是一个正整数 ww,表示口袋承重上限。
  • 22 行是一个正整数 ss,表示金属种类。
  • 33 行有 2s2s 个正整数,依次为 n1,v1,n2,v2,,ns,vsn_1, v_1, n_2, v_2, \ldots, n_s, v_s,分别表示每种金属的总重量和总价值。

输出格式

输出 kk 行,每行对应一组输入的答案。输出结果保留两位小数。

样例

2
50
4
10 100 50 30 7 34 87 100
10000
5
1 43 43 323 35 45 43 54 87 43
171.93
508.00

数据范围

  • 1k1001 \le k \le 100
  • 1w100001 \le w \le 10000
  • 1s1001 \le s \le 100
  • 1ni,vi100001 \le n_i, v_i \le 10000