[GESP202406 四级] 宝箱题解
DoubleQLzn · · 个人记录
本篇题解所用知识点:
- 【3】递推法
首先,我们可以用
接着,我们可以枚举每个区间
由于每个
Code
#include <bits/stdc++.h>
using namespace std;
long long f[2005],sum[2005],a[2005];
int main()
{
long long n,k,ma = 0;
cin >> n >> k;
for (int i = 1;i <= n;i++)
{
cin >> a[i];
f[a[i]] += a[i];
}
for (int i = 1;i <= 1000;i++)
{
sum[i] = sum[i - 1] + f[i];
}
for (int i = 1;i <= 1000;i++)
{
ma = max(ma,sum[i + k] - sum[i - 1]);
}
cout << ma;
return 0;
}