题目背景

对应的选择、判断题: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!

Logo

智能硬件社区聚焦AI智能硬件技术生态,汇聚嵌入式AI、物联网硬件开发者,打造交流分享平台,同步全国赛事资讯、开展 OPC 核心人才招募,助力技术落地与开发者成长。

更多推荐