5946 - 优先购买

题目描述

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

小 A 的购物策略为:

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

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

输入

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

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

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

输出

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

样例

输入

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

输出

bus
cab
water
说明

数据范围

对于所有测试点,保证 1 \le |S_i| \le 10,1 \le M,P_i \le 10^5 , 1 \le N \le 10^3,1 \le V_i \le 10。商品名仅由小写字母组成且不存在两个相同的商品名。

来源

GESP 2025年12月认证 C++4级真题

标签
题目参数
时间限制 1 秒
内存限制 512 MB
提交次数 20
通过人数 10
金币数量 1 枚
难度 入门


上一题 下一题