GESP 四级 C++ 题目:优先购买
题目描述
小 A 有 M 元预算。商店有 N 个商品,每个商品有商品名 S、价格 P 和优先级 V 三种属性,其中 V 为正整数,且 V 越小代表商品的优先级越高。
小 A 的购物策略为:
- 总是优先买优先级最高的东西;
- 如果有多个最高优先级商品,购买价格最低的;
- 如果有多个优先级最高且价格最低的商品,购买商品名字典序最小的。
小 A 想知道能购买哪些商品。
输入格式
第一行两个正整数 M, N,代表预算和商品数。
之后 N 行,每行一个商品,依次为 Si Pi Vi,代表第 i 个商品的商品名、价格、优先级。
数据保证不存在两个名字相同的商品。
输出格式
按照字典序从小到大的顺序,输出所有购买商品的商品名。
输入输出样例 #1
输入 #1
20 4 apple 6 8 bus 15 1 cab 1 10 water 4 8
输出 #1
bus cab water
说明/提示
数据范围
对于所有测试点,保证 1≤|Si|≤10,1≤M,Pi≤10^5,1≤N≤10^3,1≤Vi≤10。商品名仅由小写字母组成且不存在两个相同的商品名。
解题思路
解题核心思路为'先按规则排序商品,再按优先级依次购买,最后整理输出结果',整体分为三个关键步骤:
- 数据封装:使用结构体统一存储每个商品的名称、价格、优先级,方便后续排序和遍历;
- 自定义排序:严格遵循题目要求的三层优先级(优先级 v→价格 p→名字典序),对所有商品进行排序,确保靠前的商品是当前最该购买的;
- 模拟购买与结果整理:遍历排序后的商品,预算足够则购买并记录商品名,最后将购买列表按字典序排序后输出,满足题目输出要求。
#include<bits/stdc++.h>
using namespace std;
int m, n;
struct node {
string s;
int p;
int v;
};
node a[1005];
vector<string> name;
bool cmp(node x, node y) {
if (x.v != y.v) return x.v < y.v;
if (x.p != y.p) return x.p < y.p;
return x.s < y.s;
}
int {
cin >> m >> n;
( i = ; i <= n; i++) {
cin >> a[i].s >> a[i].p >> a[i].v;
}
(a + , a + n + , cmp);
( i = ; i <= n; i++) {
(a[i].p <= m) {
name.(a[i].s);
m -= a[i].p;
}
}
(name.(), name.());
( i = ; i < name.(); i++) {
cout << name[i] << ;
}
;
}

