BZOJ 1084: [SCOI2005]最大子矩阵 DP
1084: [SCOI2005]最大子矩阵
题目连接:
http://www.lydsy.com/JudgeOnline/problem.php?id=1084
Description
这里有一个n*m的矩阵,请你选出其中k个子矩阵,使得这个k个子矩阵分值之和最大。注意:选出的k个子矩阵不能相互重叠。
Input
第一行为n,m,k(1≤n≤100,1≤m≤2,1≤k≤10),接下来n行描述矩阵每行中的每个元素的分值(每个元素的分值的绝对值不超过32767)。
Output
只有一行为k个子矩阵分值之和最大为多少。
Sample Input
3 2 2
1 -3
2 3
-2 3
Sample Output
9
Hint
题意
题解:
首先我们注意m只有2
所以我们分开考虑即可,m=1的时候,dp[i][k]表示考虑第i个,分割了k块的最大值,然后无脑转移就好了
m=2的时候也是一样的,dp[i][j][k]表示上面考虑到第i个,下面考虑到了第j个,分割了k块
代码
#include<bits/stdc++.h>
using namespace std;
int n,m,k;
int sum1[120];
int sum2[120];
int dp1[120][12];
int dp2[120][120][12];
void solve1()
{
for(int i=1;i<=n;i++)
{
int x;scanf("%d",&x);
sum1[i]=sum1[i-1]+x;
}
for(int i=1;i<=n;i++)
for(int j=0;j<i;j++)
for(int t=1;t<=k;t++)
{
dp1[i][t]=max(dp1[i][t],dp1[j][t-1]+sum1[i]-sum1[j]);
dp1[i][t]=max(dp1[i][t],dp1[j][t]);
}
printf("%d\n",dp1[n][k]);
}
void solve2()
{
for(int i=1;i<=n;i++)
{
int x,y;scanf("%d%d",&x,&y);
sum1[i]=sum1[i-1]+x;
sum2[i]=sum2[i-1]+y;
}
for(int i=1;i<=n;i++)
{
for(int j=1;j<=n;j++)
{
if(i==j)
{
for(int x=0;x<i;x++)
{
for(int t=1;t<=k;t++)
{
dp2[i][j][t]=max(dp2[i][j][t],dp2[x][x][t-1]+sum1[i]-sum1[x]+sum2[i]-sum2[x]);
dp2[i][j][t]=max(dp2[i][j][t],dp2[x][x][t]);
}
}
}
for(int i2=0;i2<i;i2++)
{
for(int t=1;t<=k;t++)
{
dp2[i][j][t]=max(dp2[i][j][t],dp2[i2][j][t-1]+sum1[i]-sum1[i2]);
dp2[i][j][t]=max(dp2[i][j][t],dp2[i2][j][t]);
}
}
for(int j2=0;j2<j;j2++)
{
for(int t=1;t<=k;t++)
{
dp2[i][j][t]=max(dp2[i][j][t],dp2[i][j2][t-1]+sum2[j]-sum2[j2]);
dp2[i][j][t]=max(dp2[i][j][t],dp2[i][j2][t]);
}
}
}
}
printf("%d\n",dp2[n][n][k]);
}
int main()
{
scanf("%d%d%d",&n,&m,&k);
if(m==1)solve1();
if(m==2)solve2();
}
BZOJ 1084: [SCOI2005]最大子矩阵 DP的更多相关文章
- [BZOJ 1084] [SCOI2005] 最大子矩阵 【DP】
题目链接:BZOJ - 1084 题目分析 我看的是神犇BLADEVIL的题解. 1)对于 m = 1 的情况, 首先可能不取 Map[i][1],先 f[i][k] = f[i - 1][k]; ...
- bzoj 1084: [SCOI2005]最大子矩阵【dp】
分情况讨论,m=1的时候比较简单,设f[i][j]为到i选了j个矩形,前缀和转移一下就行了 m=2,设f[i][j][k]为1行前i个,2行前j个,一共选了k个,i!=j的时候各自转移同m=1,否则转 ...
- BZOJ 1084 [SCOI2005]最大子矩阵 - 动态规划
传送门 题目大意: 从矩阵中取出k个互不重叠的子矩阵,求最大的和. 题目分析: 对于m=1,直接最大m子段和. 对于m=2: \(dp[i][j][k]\)表示扫描到第一列i和第2列j时选取了k个矩阵 ...
- BZOJ: 1084: [SCOI2005]最大子矩阵
NICE 的DP 题,明白了题解真是不错. Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1228 Solved: 622[Submit][Stat ...
- 【BZOJ 1084】 1084: [SCOI2005]最大子矩阵 (DP)
1084: [SCOI2005]最大子矩阵 Description 这里有一个n*m的矩阵,请你选出其中k个子矩阵,使得这个k个子矩阵分值之和最大.注意:选出的k个子矩阵不能相互重叠. Input 第 ...
- BZOJ(6) 1084: [SCOI2005]最大子矩阵
1084: [SCOI2005]最大子矩阵 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 3566 Solved: 1785[Submit][Sta ...
- 1084: [SCOI2005]最大子矩阵
1084: [SCOI2005]最大子矩阵 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1325 Solved: 670[Submit][Stat ...
- Bzoj 1088: [SCOI2005]扫雷Mine (DP)
Bzoj 1088: [SCOI2005]扫雷Mine 怒写一发,算不上DP的游戏题 知道了前\(i-1\)项,第\(i\)项会被第二列的第\(i-1\)得知 设\(f[i]\)为第一列的第\(i\) ...
- 洛谷P2331 [SCOI2005]最大子矩阵 DP
P2331 [SCOI2005]最大子矩阵 题意 : 这里有一个n*m的矩阵,请你选出其中k个子矩阵,使得这个k个子矩阵分值之和最大.注意:选出的k个子矩阵不能相互重叠. 第一行为n,m,k(1≤n≤ ...
随机推荐
- 锁之“重量级锁”Synchronized
一.Synchronized的基本使用 Synchronized是Java中解决并发问题的一种最常用的方法,也是最简单的一种方法.Synchronized的作用主要有三个:(1)确保线程互斥的访问同步 ...
- DOM笔记(十):JavaScript正则表达式
一.RegExp ECMAScript通过RegExp类型类支持正则表达式,语法和Perl类似: var exp = /pattern/flags; patternb部分是任何简单的或复杂的正则表达式 ...
- Epic - Snake Sequence
You are given a grid of numbers. A snakes equence is made up of adjacent numbers such that for each ...
- PHP中mysql_affected_rows()和mysql_num_rows()区别
mysql_affected_rows -- 取得前一次 MySQL 操作所影响的记录行数mysql_num_rows -- 函数返回结果集中行的数目. config.php <?php hea ...
- servicestack操作redis
tatic void Main(string[] args) { );//redis服务IP和端口 #region =insert= var storeMembers = new List<st ...
- [翻译]HTML中不知名的语义标签
原文:http://docs.webplatform.org/wiki/tutorials/Lesser_-_known_semantic_elements HTML5中比较常用的语义元素有heade ...
- sqlserver安装相关问题
最近在部署一个工程,数据库(sqlserver2005develop)遇到不少问题,下面将一一列出. 安装完毕后,无法连接到本地实例. 打开microsoft sql server 2005-> ...
- 让一个div可以编辑加上contenteditable=true 复制来的内容带有样式,需要清除复制的样式
sEv传keyup进去 function(id,sEv){ id.on(sEv,function(){ var str = $(this).html(); //获取复制进来的内容 var re=/&l ...
- Django Signals 从实践到源码分析(转)
原文:http://foofish.net/blog/66/django-signals 当某个事件发生的时候,signal(信号)允许senders(发送者)用来通知receivers(接收者),通 ...
- POJ 1410 Intersection(判断线段交和点在矩形内)
Intersection Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 9996 Accepted: 2632 Desc ...