021 Pencils and Boxes (CF985E)

3 篇文章 0 订阅
2 篇文章 0 订阅
  • 题目链接: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,目前原因还没找到,忘路过的大佬们能帮忙看看这个情况出现的原因

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值