D最后一组数据是啥,该代码本地测试错误为什么能过

#include <bits/stdc++.h>

const int N = 2e3 + 10;
long long a[N],dp[N];

int main()
{
    long long n,m;
    std::cin >> n >> m;

    memset(dp,0x3f,sizeof dp);
    
    for(int i = 1; i <= n; i++)    
    {
        std::cin >> a[i],dp[a[i]%m] = 1;
    }
    
    for(int i = 1; i <= n; i++)
    {
        for(int mod = m - 1; mod >= 0; mod--)
        {
            dp[mod] = std::min(dp[mod],dp[(mod - (a[i]%m) + m)%m] + 1);
        }
        
    }

    std::cout << dp[0] << std::endl;
    return 0;
}
4 2000
1 3 5 2

全部评论

相关推荐

盖茨伯爵:一样兄弟,我从4月开始发到现在了,都三四百个了
无实习如何秋招上岸
点赞 评论 收藏
分享
07-10 14:08
已编辑
江西农业大学 Java
念旧select:做完把项目放到自己硬盘里给他看,看完拷走
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务