2389: 优先购买(2025年12月C++四级)

Memory Limit:512 MB Time Limit:1.000 S
Judge Style:Text Compare Creator:
Submit:1 Solved:1

Description

 A M元预算。商店有N个商品,每个商品有商品名S、价格P和优先级V三种属性,其中V为正整数,且V越小代表商品的优先级越高。

 A 的购物策略为:

  • 总是优先买优先级最高的东西;
  • 如果有多个最高优先级商品,购买价格最低的;
  • 如果有多个优先级最高且价格最低的商品,购买商品名字典序最小的。

 A 想知道能购买哪些商品。

Input

第一行两个正整数M,N,代表预算和商品数。

之后N行,每行一个商品,依次为Si Pi Vi,代表第i个商品的商品名、价格、优先级。

数据保证不存在两个名字相同的商品。

Output

按照字典序从小到大的顺序,输出所有购买商品的商品名。

Sample Input Copy

20 4
apple 6 8
bus 15 1
cab 1 10
water 4 8

Sample Output Copy

bus
cab
water

HINT

对于所有测试点,保证 1<=|Si|<=10,1<=M,Pi<=10^5,1<=N<=10^3,1<=Vi<=10。商品名仅由小写字母组成且不存在两个相同的商品名。

Source/Category