dp * 3
cf 467 C
从序列中选出 \(k\) 段连续的 \(m\) 个数
最大化总和
\(f_{i, j}\) 表示前 \(i\) 个位置中选出了 \(j\) 段
转移显然
#include <bits/stdc++.h>
const int N = 5010;
long long f[N][N];
int n, m, k;
long long Sum[N];
int main() {
std:: cin >> n >> m >> k;
for(int i = 1; i <= n; i ++) {
std:: cin >> Sum[i];
Sum[i] += Sum[i - 1];
}
for(int i = 1; i <= n; i ++) {
for(int j = 1; j <= k; j ++) {
if(i - m + 1 > 0) f[i][j] = f[i - m][j - 1] + Sum[i] - Sum[i - m];
f[i][j] = std:: max(f[i - 1][j], f[i][j]);
}
}
std:: cout << f[n][k];
return 0;
}
51nod 1354
给出序列 \(a\) 和一个整数 \(k\)
求子序列的乘积是 \(k\) 的倍数的方案数
\(f_{i, j}\) 表示前 \(i\) 个数,乘积是 \(j\) 的方案数
\(f_{i, j} = f_{i - 1, \frac{j}{a_{i - 1}}} + f_{i - 1, j}\)
由于 \(k\) 很大
显然单纯的数组是无法完成的
这里可以使用 \(map\), 通过遍历完成
#include <bits/stdc++.h>
const int N = 1010, Mod = 1e9 + 7;
std:: map <int, int> Map[N];
int n, k, t;
int A[N];
int main() {
std:: cin >> t;
for(; t; t --) {
std:: cin >> n >> k;
Map[0].clear();
for(int i = 1; i <= n; i ++) {
std:: cin >> A[i];
Map[i].clear();
}
Map[0][k] = 1;
for(int i = 0; i < n; i ++)
for(std:: map <int, int> :: iterator it = Map[i].begin(); it != Map[i].end(); it ++) {
if(it-> first % A[i + 1] == 0)
(Map[i + 1][it-> first / A[i + 1]] += it-> second) %= Mod;
(Map[i + 1][it-> first] += it-> second) %= Mod;
}
std:: cout << Map[n][1] << "\n";
}
return 0;
}
openjudge 6047
\(w \times h\) 的蛋糕,切成 \(m\) 块
每刀可以将一块切成两块
求最小化的最大蛋糕面积
\(f_{i, j, k}\) 表示将 \(i \times j\) 的蛋糕切成 \(m\) 块时的最小化的最大蛋糕面积
枚举蛋糕的长和宽以及切成的块数
固定好后枚举长从哪里分割 \(h\) 以及分成的块数 \(p\)
\(f_{i, j, k} = min(f_{i, j, k}, max(f_{h, j, p}, f_{i - h, j, p}))\)
同理枚举列
\(f_{i, j, k} = min(f_{i, j, k}, max(f_{i, l, p}, f_{i, j - l, p}))\)
#include <bits/stdc++.h>
const int N = 25;
int f[N][N][N];
int main() {
int w, h, m;
while(std:: cin >> w >> h >> m) {
memset(f, 0, sizeof f);
if(w == 0 && h == 0 && m == 0) break;
for(int i = 1; i <= w; i ++)
for(int j = 1; j <= h; j ++)
f[i][j][1] = i * j;
for(int i = 1; i <= w; i ++)
for(int j = 1; j <= h; j ++)
for(int k = 2; k <= std:: min(i * j, m); k ++) {
f[i][j][k] = (1 << 30);
for(int H = 1; H < i; H ++)
for(int p = 1; p < k; p ++)
f[i][j][k] = std:: min(f[i][j][k], std:: max(f[H][j][p], f[i - H][j][k - p]));
for(int L = 1; L < j; L ++)
for(int p = 1; p < k; p ++)
f[i][j][k] = std:: min(f[i][j][k], std:: max(f[i][L][p], f[i][j - L][k - p]));
}
std:: cout << f[w][h][m] << "\n";
}
return 0;
}
dp * 3的更多相关文章
- BZOJ 1911: [Apio2010]特别行动队 [斜率优化DP]
1911: [Apio2010]特别行动队 Time Limit: 4 Sec Memory Limit: 64 MBSubmit: 4142 Solved: 1964[Submit][Statu ...
- 2013 Asia Changsha Regional Contest---Josephina and RPG(DP)
题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=4800 Problem Description A role-playing game (RPG and ...
- AEAI DP V3.7.0 发布,开源综合应用开发平台
1 升级说明 AEAI DP 3.7版本是AEAI DP一个里程碑版本,基于JDK1.7开发,在本版本中新增支持Rest服务开发机制(默认支持WebService服务开发机制),且支持WS服务.RS ...
- AEAI DP V3.6.0 升级说明,开源综合应用开发平台
AEAI DP综合应用开发平台是一款扩展开发工具,专门用于开发MIS类的Java Web应用,本次发版的AEAI DP_v3.6.0版本为AEAI DP _v3.5.0版本的升级版本,该产品现已开源并 ...
- BZOJ 1597: [Usaco2008 Mar]土地购买 [斜率优化DP]
1597: [Usaco2008 Mar]土地购买 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 4026 Solved: 1473[Submit] ...
- [斜率优化DP]【学习笔记】【更新中】
参考资料: 1.元旦集训的课件已经很好了 http://files.cnblogs.com/files/candy99/dp.pdf 2.http://www.cnblogs.com/MashiroS ...
- BZOJ 1010: [HNOI2008]玩具装箱toy [DP 斜率优化]
1010: [HNOI2008]玩具装箱toy Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 9812 Solved: 3978[Submit][St ...
- px、dp和sp,这些单位有什么区别?
DP 这个是最常用但也最难理解的尺寸单位.它与“像素密度”密切相关,所以 首先我们解释一下什么是像素密度.假设有一部手机,屏幕的物理尺寸为1.5英寸x2英寸,屏幕分辨率为240x320,则我们可以计算 ...
- android px转换为dip/dp
/** * 根据手机的分辨率从 dp 的单位 转成为 px(像素) */ public int dipTopx(Context context, float dpValue) { final floa ...
- POJ 3254. Corn Fields 状态压缩DP (入门级)
Corn Fields Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 9806 Accepted: 5185 Descr ...
随机推荐
- Spring Boot使用@ConfigurationProperties注解获取配置文件中的属性值
注意:这种方式要提供属性的getter/setter方法—— 如果idea报错,提示没有相应的执行器,就需要在maven中添加: (虽然不配置代码也能正常运行,作用在下面会说明) 配置了该执行器后,在 ...
- [Luogu5324][BJOI2019]删数(线段树)
CF风格题,先猜结论,记数列中i这个数共出现了cnt[i]次,那么所有区间[i-cnt[i]+1,i]的并集的补集大小就是答案. 于是我们只需要线段树维护每个位置是否被某个区间覆盖到即可,对于整体加减 ...
- Java8新特性 - 方法引用与构造器引用
方法引用 若Lambda体中的内容有方法已经实现了,我们可以使用"方法应用",可以理解为方法引用是Lambda表达式的另外一种表现形式. 使用操作符"::"将方 ...
- 在论坛中出现的比较难的sql问题:13(循环替换问题 过滤各种标点符号)
原文:在论坛中出现的比较难的sql问题:13(循环替换问题 过滤各种标点符号) 所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路. 去掉一个字段中的标点符号的SQL语句怎么写 ...
- winserver2012远程桌面进入只有CMD窗口,无桌面解决方法
原因:.net framework4.5是Windows server图形化界面的基础,系统还原时只装了核心模式core,系统没有了图形界面当然只有cmd了 解决方法:使用dism命令需要将核心模 ...
- element-ui 表格错行
//表格错行 .el-table th.gutter { display: table-cell !important }
- java网络编程--httpurlconnection
HttpURLConnection是基于HTTP协议的,其底层通过socket通信实现.如果不设置超时(timeout),在网络异常的情况下,可能会导致程序僵死而不继续往下执行.可以通过以下两个语句来 ...
- Nginx的反向代理和负载均衡服务
Nginx (engine x) 是一个高性能的HTTP和反向代理服务,也是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,并在一个BSD-like 协议下发行. ...
- Git 日常命令
克隆项目:git clone addr dir 切换分支,分支并没有 git checkout -b production origin/production 分支已存在,单纯切换分支 git c ...
- SQL SERVER-修改服务器名称
--query servername SELECT @@SERVERNAME --alter servername sp_dropserver 'oldname' go sp_addserver 'n ...