题目描述
商店里有N件唯一性商品,每件商品有一个价格,第 i 件商品的价格是 ai。
一个购买方案可以是从N件商品种选择任意件进行购买(至少一件),花费即价格之和。
现在你需要求出所有购买方案中花费前K小的方案,输出这些方案的花费。
当两个方案选择的商品集合至少有一件不同,视为不同方案,因此可能存在两个方案花费相同。
输入描述
输入数据含两行:文章来源:https://www.toymoban.com/news/detail-650307.html
- 第一行包含两个整数N,K,整数之间通过空格隔开。分别表示商品的个数,以及需要求得的花费个数。1 ≤ N ≤ 10000,1 ≤ K ≤ min(2^N - 1,100000)
- 第二行包含N个整数a1,a2,...,an,整数之间通过空格隔开。表示N件商品的价格。1 ≤ a1 ≤ a2 ≤ ... ≤ an ≤ 10000
输出描述
按花费从小到大的顺序依次输出K行,一行一个整数。表示花费前K小的购买方案的花费。文章来源地址https://www.toymoban.com/news/detail-650307.html
用例
输入 | 5 6 1 1 2 3 3 |
输出 |
到了这里,关于华为OD机试 - 购物(Java & JS & Python)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!