【问题描述】
小杨发现了n 个宝箱,其中第i 个宝箱的价值是 。
小杨可以选择一些宝箱放入背包并带走,但是小杨的背包比较特殊,假设小杨选择的宝箱中最大价值为x ,最小价值为x ,小杨需要保证 ,否则小杨的背包会损坏。
小杨想知道背包不损坏的情况下,自己能够带走宝箱的总价值最大是多少。
【输入描述】
第一行包含两个正整数 n,k,含义如题面所示。
第二行包含 n个正整数 ,代表宝箱的价值。
【输出描述】
输出一个整数,代表带走宝箱的最大总价值。
【样例输入1】
5 1
1 2 3 1 2
【样例输出1】
7
【样例解释】
在背包不损坏的情况下,小杨可以拿走两个价值为 2的宝箱和一个价值为3的宝箱。
【数据范围】
对于全部数据,保证有。
参考答案:
- def func(index):
- max_ = lst[index]
- total = max_
- for j in range(index - 1, -1, -1):
- if max_ - lst[j] <= k:
- total += lst[j]
- else:
- break
- return total
- n, k = map(int, input().split())
- lst = sorted(map(int, input().split()))
- result = 0
- for i in range(n - 1, -1, -1):
- a = func(i)
- if a > result:
- result = a
- print(result)