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的更多相关文章

  1. BZOJ 1911: [Apio2010]特别行动队 [斜率优化DP]

    1911: [Apio2010]特别行动队 Time Limit: 4 Sec  Memory Limit: 64 MBSubmit: 4142  Solved: 1964[Submit][Statu ...

  2. 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 ...

  3. AEAI DP V3.7.0 发布,开源综合应用开发平台

    1  升级说明 AEAI DP 3.7版本是AEAI DP一个里程碑版本,基于JDK1.7开发,在本版本中新增支持Rest服务开发机制(默认支持WebService服务开发机制),且支持WS服务.RS ...

  4. AEAI DP V3.6.0 升级说明,开源综合应用开发平台

    AEAI DP综合应用开发平台是一款扩展开发工具,专门用于开发MIS类的Java Web应用,本次发版的AEAI DP_v3.6.0版本为AEAI DP _v3.5.0版本的升级版本,该产品现已开源并 ...

  5. BZOJ 1597: [Usaco2008 Mar]土地购买 [斜率优化DP]

    1597: [Usaco2008 Mar]土地购买 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 4026  Solved: 1473[Submit] ...

  6. [斜率优化DP]【学习笔记】【更新中】

    参考资料: 1.元旦集训的课件已经很好了 http://files.cnblogs.com/files/candy99/dp.pdf 2.http://www.cnblogs.com/MashiroS ...

  7. BZOJ 1010: [HNOI2008]玩具装箱toy [DP 斜率优化]

    1010: [HNOI2008]玩具装箱toy Time Limit: 1 Sec  Memory Limit: 162 MBSubmit: 9812  Solved: 3978[Submit][St ...

  8. px、dp和sp,这些单位有什么区别?

    DP 这个是最常用但也最难理解的尺寸单位.它与“像素密度”密切相关,所以 首先我们解释一下什么是像素密度.假设有一部手机,屏幕的物理尺寸为1.5英寸x2英寸,屏幕分辨率为240x320,则我们可以计算 ...

  9. android px转换为dip/dp

    /** * 根据手机的分辨率从 dp 的单位 转成为 px(像素) */ public int dipTopx(Context context, float dpValue) { final floa ...

  10. POJ 3254. Corn Fields 状态压缩DP (入门级)

    Corn Fields Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 9806   Accepted: 5185 Descr ...

随机推荐

  1. <a>的javascript+jquery编程实例之删除(定位节点与事件绑定)

    相关jquery方法 parent(), remove() //上传图片 article_create.js article_edit.js function uploadAttachment() { ...

  2. 【转载】程序设计过程中SQL语句Where 1=1的作用

    在Asp.Net网站或者Java网站的程序设计的过程中,很多时候我们可以看到拼接SQL语句的写法的时候都可以看到最前面有个Where 1=1这个条件,其实Where 1=1这是个恒等式,SQL语句写成 ...

  3. Java 之 Junit 单元测试

    Junit 单元测试 测试分类: 1.黑盒测试:不需要写代码,给输入值,看程序是否能够输出期望的值. 2.白盒测试:需要写代码.关注程序具体的执行流程. Junit 测试:(属于白盒测试) 步骤: 1 ...

  4. linux文件比较

    Linux文件比较指令有两个,comm和diff,其中comm要求的是排序过得文件.Diff则没有这个要求,diff的输出结果主要是用来表明文件一经过怎样的修改可以得到文件二. Comm Comm的语 ...

  5. Leaflet 调用百度瓦片地图服务

    在使用 leaflet 调用第三方瓦片地图服务的项目,主要谷歌地图.高德地图.百度地图和 OSM 地图,与其他三种地图对比,百度地图的瓦片组织方式是不同的.百度从中心点经纬度(0,0)度开始计算瓦片, ...

  6. echart——vue封装成公共组件

    <!-- 自定义Echarts * options: Object,//数据 * theme: String,//主题 * initOptions: Object,//初始化 * group: ...

  7. Python中的上下文管理器(contextlib模块)

    上下文管理器的任务是:代码块执行前准备,代码块执行后收拾 1 如何使用上下文管理器: 打开一个文件,并写入"hello world" filename="my.txt&q ...

  8. Centos7.6进入挂载硬盘后,进入应急模式(emergency mode)而非图形模式解决方法

    Centos7.6进入挂载硬盘后,进入应急模式(emergency mode)而非图形模式解决方法 话说某天我想在centos7.6中挂载个硬盘,结果刚在虚拟机中添加了一块硬盘,再次打开系统时,居然就 ...

  9. Python基础——__name__变量

    转自:https://blog.csdn.net/u011511601/article/details/53504355 Python使用缩进对齐组织代码的执行,所有没有缩进的代码,都会在载入时自动执 ...

  10. TIME_WAIT状态全是3306解决办法

    刚吃完晚饭,手机短信一直响个不停,打开一看全是告警信息,立即打开电脑查看,发现很多网页很不稳定  一会能打开,一会打不开 登录服务器查看负载情况,cpu.内存 .磁盘io 负载都不高,查看日志发现ng ...