B4452 [GESP202512 四级] 优先购买
商店有 N 个商品,每个商品有商品名 S、价格 P 和优先级 V 三种属性,其中 V 为正整数,且 V 越小代表商品的优先级越高。对于所有测试点,保证 1≤∣Si∣≤10,1≤M,Pi≤105,1≤N≤103,1≤Vi≤10。商品名仅由小写字母组成且不存在两个相同的商品名。之后 N 行,每行一个商品,依次为 Si Pi Vi,代表第 i 个商品的商品名、价格、优先级。按照字典序从小到大
·
题目背景
对应的选择、判断题:https://ti.luogu.com.cn/problemset/1200
题目描述
小 A 有 M 元预算。商店有 N 个商品,每个商品有商品名 S、价格 P 和优先级 V 三种属性,其中 V 为正整数,且 V 越小代表商品的优先级越高。
小 A 的购物策略为:
- 总是优先买优先级最高的东西;
- 如果有多个最高优先级商品,购买价格最低的;
- 如果有多个优先级最高且价格最低的商品,购买商品名字典序最小的。
小 A 想知道能购买哪些商品。
输入格式
第一行两个正整数 M,N,代表预算和商品数。
之后 N 行,每行一个商品,依次为 Si Pi Vi,代表第 i 个商品的商品名、价格、优先级。
数据保证不存在两个名字相同的商品。
输出格式
按照字典序从小到大的顺序,输出所有购买商品的商品名。
输入输出样例
输入 #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≤105,1≤N≤103,1≤Vi≤10。商品名仅由小写字母组成且不存在两个相同的商品名。
思路:
用struct函数:
#include<bits/stdc++.h>
using namespace std;
struct shop{
string s;
int p, v;
};
shop a[10000];
bool cmp(shop a, shop b){
if(a.v != b.v){
return a.v < b.v;
}
if(a.p != b.p){
return a.p < b.p;
}
return a.s < b.s;
}
string r[10000];
int cnt;
int main(){
int m, n;
cin >> m >> n;
for(int i = 1;i <= n;i++){
cin >> a[i].s >> a[i].p >> a[i].v;
}
sort(a+1, a+1+n, cmp);
for(int i = 1;i <= n;i++){
if(m >= a[i].p){
m -= a[i].p;
r[++cnt] = a[i].s;
}
}
sort(r+1, r+1+cnt);
for(int i = 1;i <= cnt;i++){
cout << r[i] << "\n";
}
return 0;
}
禁止复制!刷ac!
更多推荐



所有评论(0)