博客
关于我
Codeforces Round #544 (Div. 3) E. K Balanced Teams(DP)
阅读量:393 次
发布时间:2019-03-05

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

在这里插入图片描述
在这里插入图片描述
题意:有n个学生,每个学生有ai值,要求把学生分成不超过k组,同时一组内学生的ai值最大不能超过5,求能组队的最大学生数。
思路:排序后,能组队的肯定是连续的数,dp【i】【j】代表前i个学生组成j个组的最大学生数,只要在第二层循环里找到满足条件的pos位置。

#include
using namespace std;const int maxn=5e3+5;int n,k,ans=0,pos=1,dp[maxn][maxn],a[maxn];int main(){ scanf("%d%d",&n,&k); for(int i=1;i<=n;++i) scanf("%d",&a[i]); sort(a+1,a+1+n); for(int i=1;i<=n;++i) { while(a[i]-a[pos]>5&&pos<=i) pos++; for(int j=1;j<=k;++j) dp[i][j]=max(dp[i-1][j],dp[pos-1][j-1]+i-pos+1); } for(int i=1;i<=k;++i) ans=max(ans,dp[n][i]); printf("%d\n",ans);}

转载地址:http://brewz.baihongyu.com/

你可能感兴趣的文章
NIO与零拷贝和AIO
查看>>
NIO同步网络编程
查看>>
NIO基于UDP协议的网络编程
查看>>
NIO笔记---上
查看>>
Vue3.0中的响应式原理(第九课)
查看>>
NIO蔚来 面试——IP地址你了解多少?
查看>>
NISP一级,NISP二级报考说明,零基础入门到精通,收藏这篇就够了
查看>>
NISP国家信息安全水平考试,收藏这一篇就够了
查看>>
NIS服务器的配置过程
查看>>
NIS认证管理域中的用户
查看>>
Nitrux 3.8 发布!性能全面提升,带来非凡体验
查看>>
NiuShop开源商城系统 SQL注入漏洞复现
查看>>
NI笔试——大数加法
查看>>
NLog 自定义字段 写入 oracle
查看>>
NLog类库使用探索——详解配置
查看>>
NLP 基于kashgari和BERT实现中文命名实体识别(NER)
查看>>
NLP 模型中的偏差和公平性检测
查看>>
Vue3.0 性能提升主要是通过哪几方面体现的?
查看>>
NLP 项目:维基百科文章爬虫和分类【01】 - 语料库阅读器
查看>>
NLP_什么是统计语言模型_条件概率的链式法则_n元统计语言模型_马尔科夫链_数据稀疏(出现了词库中没有的词)_统计语言模型的平滑策略---人工智能工作笔记0035
查看>>