和「理想的正方形」比较相似,需要先掌握那道题。

花坛外头每一边必须套上绿化带

#include <iostream>
#include <cstdio>
using namespace std;
int n, m, a, b, c, d, qwq[1005], twq, hwq, zzxz[1005][1005], ans;
int r[1005][1005], hzxz[1005][1005], cd[1005][1005], ab[1005][1005];
int main(){
cin>>n>>m>>a>>b>>c>>d;
for(int i=1; i<=n; i++)
for(int j=1; j<=m; j++){
scanf("%d", &r[i][j]);
r[i][j] += r[i-1][j] + r[i][j-1] - r[i-1][j-1];
}
for(int i=1; i<=n-c+1; i++)
for(int j=1; j<=m-d+1; j++){
int k=i+c-1;
int l=j+d-1;
cd[i][j] = r[k][l] - r[i-1][l] - r[k][j-1] + r[i-1][j-1];//计算所有c*d区域的和
}
for(int i=1; i<=n-a+1; i++)
for(int j=1; j<=m-b+1; j++){
int k=i+a-1;
int l=j+b-1;
ab[i][j] = r[k][l] - r[i-1][l] - r[k][j-1] + r[i-1][j-1];
}
a -= 2 + c - 1;//a*b的区域,是(a-2)*(b-2)的区域能放,然后再抛去c*d的大小带来的影响,就成了寻找一定区域内的最小值(因为要枚举a*b区域左上角,然后用单调队列迅速求出它所对应的(a-2)*(b-2)区域内的c*d区域的和的最小值),这样就方便了处理
b -= 2 + d - 1;
n -= c - 1;//这个矩阵就变成了所有c*d区域的和的矩阵
m -= d - 1;
for(int i=1; i<=n; i++){
hwq = 1;
twq = 0;
for(int j=1; j<=m; j++){
int t=max(1, j-b+1);
while(hwq<=twq && qwq[hwq]<=j-b) hwq++;
while(hwq<=twq && cd[i][qwq[twq]]>cd[i][j]) twq--;
qwq[++twq] = j;
hzxz[i][t] = cd[i][qwq[hwq]];
}
}
for(int i=1; i<=m-b+1; i++){
hwq = 1;
twq = 0;
for(int j=1; j<=n; j++){
int t=max(1, j-a+1);
while(hwq<=twq && qwq[hwq]<=j-a) hwq++;
while(hwq<=twq && hzxz[qwq[twq]][i]>hzxz[j][i]) twq--;
qwq[++twq] = j;
zzxz[t][i] = hzxz[qwq[hwq]][i];
}
}
n += c - 1;
m += d - 1;
a += 2 + c - 1;
b += 2 + d - 1;
for(int i=1; i<=n-a+1; i++)
for(int j=1; j<=m-b+1; j++)
ans = max(ans, ab[i][j]-zzxz[i+1][j+1]);
cout<<ans<<endl;
return 0;
}

luogu2219 [HAOI2007]修筑绿化带的更多相关文章

  1. P2219 [HAOI2007]修筑绿化带(单调队列)

    P2219 [HAOI2007]修筑绿化带 二维单调队列 写了这题 P2216 [HAOI2007]理想的正方形  后,你发现可以搞个二维单调队列 来保存矩形(i+1,i+A-1)(j+1,j+B-1 ...

  2. 洛谷2219:[HAOI2007]修筑绿化带——题解

    https://www.luogu.org/problemnew/show/P2219#sub 为了增添公园的景致,现在需要在公园中修筑一个花坛,同时在画坛四周修建一片绿化带,让花坛被绿化带围起来. ...

  3. [HAOI2007] 修筑绿化带

    类型:单调队列 传送门:>Here< 题意:给出一个$M*N$的矩阵,每一个代表这一格土地的肥沃程度.现在要求修建一个$C*D$的矩形花坛,矩形绿化带的面积为$A*B$,要求花坛被包裹在绿 ...

  4. [luoguP2219] [HAOI2007]修筑绿化带(单调队列)

    传送门 需要n*m的算法,考虑单调队列 可以预处理出来 a[i][j]表示以i,j为右下角的绿化带+花坛的和 b[i][j]表示以i,j为右下角的花坛的和 那么我们可以单调队列跑出来在A-C-1,B- ...

  5. 洛谷.2219.[HAOI2007]修筑绿化带(单调队列)

    题目链接 洛谷 COGS.24 对于大的矩阵可以枚举:对于小的矩阵,需要在满足条件的区域求一个矩形和的最小值 预处理S2[i][j]表示以(i,j)为右下角的C\(*\)D的矩阵和, 然后对于求矩形区 ...

  6. P2219 [HAOI2007]修筑绿化带

    我是题面 这道题跟理想的正方形很像,不大明白蛤OI是怎么想的,一年出两道这么相近的题 这道题有两个矩形,所以就有了两种做法(说是两种做法,其实只是维护的矩形不同) 一种是维护大矩形,一种是维护小矩形, ...

  7. 洛谷P2219 [HAOI2007]修筑绿化带(单调队列)

    传送门 啧……明明以前做到过这种类型的题结果全忘了…… 这种矩阵的,一般都是先枚举行,然后对列进行一遍单调队列,搞出右下角在每一行中合法位置时的最小权值 再枚举列,对行做一遍单调队列,用之前搞出来的最 ...

  8. luogu 2219[HAOI2007]修筑绿化带 单调队列

    Code: #include<bits/stdc++.h> using namespace std; #define setIO(s) freopen(s".in",& ...

  9. [HAOI2007]修筑绿化带 题解

    题意分析 给出一个 $m*n$ 的矩阵 $A$ ,要求从中选出一个 $a*b$ 的矩阵 $B$ ,再从矩阵 $B$ 中选出一个 $c*d$ 的矩阵 $C$ ,要求矩阵 $B,C$ 的边界不能重合,求矩 ...

随机推荐

  1. HTML <form> 标签的 enctype

    form的enctype有三种 application/x-www-form-urlencoded 在发送前编码所有字符(默认) multipart/form-data 不对字符编码. 在使用包含文件 ...

  2. watir-webdriver使用过程中异常

    1.在jruby版本1.6.7中,报异常:not such file to load --watir-webdriver 解决方法 :在文件的首行添加:require 'rubygems'       ...

  3. JAVA吃货联盟项目。

    1基础通过数组.选择结构.循环等实 现吃货联盟订餐系统. 1.我要订餐: 2.查看餐袋: 3.签收订单: 4.删除订单: 5.我要点赞: 6.退出系统: public class Doy001 { p ...

  4. [转](不理想)Ubuntu下更改主显示器

    参考链接:http://www.cnblogs.com/feng_013/archive/2012/03/05/2380111.html 查看显示器信息: fdm@fdm-OptiPlex-780:~ ...

  5. Web 前端开发代码规范(基础)

    一. 引言 对于一个多人团队来说,制定一个统一的规范是必要的,因为个性化的东西无法产生良好的聚合效果,规范化可以提高编码工作效率,使代码保持统一的风格,以便于代码整合和后期维护. 二. HTML/CS ...

  6. Java类的静态块の二

    在上一篇Java类的静态块の一中介绍到:类的静态块在类加载时候执行,执行早于构造函数,并且只执行一次. 但是在下面的例子中却发现JVM并不是把把所有的static模块都执行完成再执行其他(Java果然 ...

  7. [原创] SOAP UI 创建SOAP工程进行接口测试

    下载及安装 1. 登录http://www.soapui.org/ 2. 鼠标移动到导航头的Downloads选项 3. 点击SOAP UI 4. 下载页面 新建项目 创建项目 1. 创建项目很简单. ...

  8. C++拾遗(三)——函数

    函数的定义 C++是一种静态强类型语言,对于每一次的函数调用,编译时都会检查其实参,必须与形参类型相同,或可被转换为该类型. 参数传递 普通的非引用类型的参数通过复制对应的实参实现初始化.引用形参直接 ...

  9. MySQL存储过程(更新指定字段的数据)

    mysql存储过程示例: USE 数据库名称;DROP PROCEDURE IF EXISTS 数据库名称.存储过程名称;delimiter $$CREATE PROCEDURE 数据库名称.存储过程 ...

  10. codevs 爱改名的小融

    都是三道水题 但我很难理解的是 string 能过 char 就WA 2967 题目描述 Description Wikioi上有个人叫小融,他喜欢改名. 他的名字都是英文,只要按顺序出现R,K,Y三 ...