博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
noi 2989 糖果
阅读量:6196 次
发布时间:2019-06-21

本文共 1245 字,大约阅读时间需要 4 分钟。

题目链接:

首先,数据很大,直接用背包会re。

这里增加的是对%k 的余数维度。f[i][j] 表示前 i 种糖果取到总颗数模 k 余数为 j 的最大颗数。

注意一定要先将 f[i-1][j] 转移到 f[i][j] ,再枚举余数dp,不然会有重叠。答案是 f[n][0];

#include 
using namespace std;int a[1050];int d[1001000];int f[110][110];/*int main(){ int n,k; int sum = 0; scanf("%d%d",&n,&k); for(int i=1;i<=n;i++) { scanf("%d",&a[i]); sum+=a[i]; } int t = sum/k; sum = t*k; for(int i=1;i<=n;i++) { for(int j=sum;j>=0;j--) { if(j>=a[i]) { d[j] = max(d[j],d[j-a[i]]+a[i]); } } } bool flag = false; for(;;) { if(d[sum]%k==0) { printf("%d\n",d[sum]); flag = true; break; } else sum = sum - k; } if(!flag) puts("0"); return 0;}*/int main(){ int n,k; scanf("%d%d",&n,&k); memset(f,0,sizeof(f)); for(int i=1; i<=n; i++) scanf("%d",&a[i]); for(int i=1; i<=n; i++) { for(int q=0; q<=k-1; q++) f[i][q]=f[i-1][q]; for(int j=0; j<=k-1; j++) if(f[i-1][j]+a[i]>f[i][(f[i-1][j]+a[i])%k]) f[i][(f[i-1][j]+a[i])%k]=f[i-1][j]+a[i]; } printf("%d",f[n][0]); return 0;}

 

转载于:https://www.cnblogs.com/TreeDream/p/6031837.html

你可能感兴趣的文章
漏洞安全
查看>>
异步任务spring @Async注解源码解析
查看>>
人工智能与未来工作
查看>>
css文字效果(文字剪贴蒙版,text-shodow的应用,文字排版等…)
查看>>
MySQL伪master+Binlog+同步【转】
查看>>
模仿以太坊 ERC20 规范的 Hyperledger Fabric 实现 Token 通证
查看>>
Asp.Net Core 如何在 IIS 中设置环境变量
查看>>
IntelliJ IDEA推荐插件
查看>>
RandomStringUtils RandomUtils
查看>>
Notification 浏览器的消息推送
查看>>
[转载]你所不了解的DevOps
查看>>
关于双十二崩盘的一些思考
查看>>
centos7 开启端口防火墙配置(如开启3306或者80端口)
查看>>
async/await使用深入详解
查看>>
uemacs快捷键
查看>>
ASP.NET编程模型:RegisterStartupScript向页面注册脚本
查看>>
LPC21O3第一课:第一个实验,LED灯闪烁及ADS1.2的初步使用
查看>>
matlab练习程序(共生矩阵)
查看>>
BizTalk Server 2006 R3 is Announced
查看>>
[译]C# Socket连接请求超时机制
查看>>