- 题目链接:CF985E
- 标签:DP,思维
- 题目大意:给你n个数,问能否将这些数分成几组,每组至少k个数,每组数极差不超过d
- 思路:先排序,用dp[i]判断这个数能否作为一个序列的结尾(这个组的最大数)
- 代码:
#include<bits/stdc++.h>
using namespace std;
#define ll long long
const int maxn=500005;
ll a[maxn];
bool dp[maxn];
int main()
{
int n,k;
ll d;
cin>>n>>k>>d;
for(int i=1;i<=n;i++)
cin>>a[i];
sort(a+1,a+1+n);
memset(dp,0,sizeof(dp));
dp[0]=1;
int p=1;
for(int i=0;i<=n;i++) {
if(dp[i]){//它是结尾的基础上,从下一个开始判断哪些可以作为结尾
p=max(p,i+k);
while(p<=n&&(a[p]-a[i+1]<=d)){//如果它可以作为结尾
dp[p]=1;
p++;
}
}
}
if(dp[n])
cout<<"YES";
else
cout<<"NO";
}
此外有一个问题就是
while((a[p]-a[i+1]<=d)&&p<=n)
如果这样子的话在75点会RE,目前原因还没找到,忘路过的大佬们能帮忙看看这个情况出现的原因