华为OD机试 - 购物 - 广度优先搜索BFS、优先队列(Python/JS/C/C++ 2025 B卷 200分)

一、题目描述

商店里有N件唯一性商品,每件商品有一个价格,每i件商品的价格是a[i]。一个购买方案可以是从N件商品中选择任意件进行购买(至少一件),花费即价格之和。

现在你需要求出所有购买方案中花费前K小的方案,输出这些方案的花费。当两个方案选择的商品集合至少有一个不同,视为不同方案,因此可能存在两个方案花费相同。

二、输入描述

输入数据位两行。

第一行包含两个整数N,K,整数之间通过空格隔开。分别表示商品的个数,以及需要求得的花费个数。

1<=N<=100000,1<=K<=min(2N-1, 1000000)

第二个记录N个整数a1, a2, …, an整数之间通过空格隔开,表示N件商品的价格。1<=a1<=a2<=…<=an<=100000

三、输出描述

按花费从小到大的顺序依次输出K行,一行一个整数,表示花费钱K小的购买方案的花费

四、测试用例

1、输入

5 6
1 1 2 3 3

2、输出

1
1
2
2
3
3

五、解题思路

1、为什么选择广度优先搜索BFS

可以按层次逐步探索

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

哪 吒

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值