[BJOI2019]排兵布阵 DP

比较好想的DP,设\(dp[i][j]\)表示第\(i\)个城堡时,已派出\(j\)个士兵。决策时,贪心派出恰好严格大于某一玩家派出的数量的两倍(不然浪费)。我们发现又可以排序预处理出\(a[i][j]\)表示第\(i\)个城堡,出兵数量第\(j\)大的人出兵数量(因为这样可以很容易算出贡献,即为\(k\times i\))

dp转移方程即为:

\[dp[j]=MAX(dp[j-a[i][k]*2-1]+k*i, dp[j]);
\]

AC Code:

#include <cstdio>
#include <algorithm>
#define MAX(A,B) ((A)>(B)?(A):(B))
using namespace std;
int s,n,m,dp[20002],a[110][110],ans;
signed main(){
scanf("%d %d %d", &s, &n, &m);
for(int i=1;i<=s;++i)
for(int j=1;j<=n;++j)
scanf("%d", &a[j][i]);
for(int i=1;i<=n;++i)
sort(a[i]+1, a[i]+1+s);
for(int i=1;i<=n;++i)
for(int j=m;j>=0;--j)
for(int k=1;k<=s;++k)
if(j>a[i][k]*2)
dp[j]=MAX(dp[j-a[i][k]*2-1]+k*i, dp[j]);
for(int i=0;i<=m;++i) ans=MAX(ans, dp[i]);
printf("%d\n", ans);
return 0;
}
/*
dp[i][j]第i个城堡时,已派出j个士兵
a[i][j]第i个城堡,第j个人出的兵
*/

最新文章

  1. F#之旅9 - 正则表达式
  2. Http、Https请求工具类
  3. iOS 面试总结 一
  4. wcf DataTable作为返回类型
  5. 【转】c# 调用windows API(user32.dll)
  6. Swift 3.0 令人兴奋,但Objective-C也有小改进--Objective-C的类属性
  7. IIS6下, web.config配置为targetFramework=&quot;4.0&quot;时出404错误
  8. 解决 “无法安装 Visual Studio 2010 Service Pack 1,因为此计算机的状态不支持”
  9. IOS开发备忘
  10. php 序列化储存和转化 json_encode() json_decode($q,true)
  11. 问题汇总-20130927-关于rc.local命令无法执行
  12. jquery-easyui界面皮肤设计
  13. (大数据工程师学习路径)第三步 Git Community Book----Git介绍
  14. Jfinal启动原理及源码简析
  15. 使用localStorage保存搜索记录
  16. mysql之concat concat_ws group_concat
  17. Vue系列之 =&gt; 父组件向子组件传值
  18. 安装zookeeper遇到的问题
  19. JOBDU 题目1100:最短路径
  20. mycat下mysql jdbc connector使用高版本报PacketTooBigException异常

热门文章

  1. python练习:函数4
  2. MySQL高版本默认密码查找
  3. 英特尔vPro博锐技术激活
  4. 最详细的原生js实现ajax的封装
  5. SQL alchemy
  6. 2 webpack 4 加vue搭建开发环境最终配置
  7. leetcode-62. Unique Paths &#183; DP + vector
  8. 2.Java集合-ConcurrentHashMap实现原理及源码分析
  9. 完整的ELK+filebeat+kafka笔记
  10. 配置Python、Django环境变量教程