【bzoj1047】理想的正方形
【bzoj1047】理想的正方形
题意
给定\(a*b\)由整数组成的矩形。
现请你从中找出一个n*n的正方形区域,使得该区域所有数中的最大值和最小值
的差最小。
\(1\leq a,b\leq 1000\)
\(1\leq n\leq 100\)
分析
枚举每一个位置,然后考虑快速求矩形内的最大值和最小值即可。
单调队列可以快速实现:
先求出\(d[i][j]\)表示\(a[i][j-n+1,j-n,...,j]\)中的最值。
然后求出\(f[i][j]\)表示\(d[i-n+1,i-n,...,i][j]\)中的最值。
所有的\(f[i][j]\)就表示以\((i,j)\)为右下角端点的矩形的最值。
也可以使用ST表。
由于\(n\)一定,所以只需要用一个简化的二维ST表即可。
\(f[i][j][k]\)表示跨度为\(2^i\),终点在\((j,k)\)的矩形的最值。
注意ST表的正确姿势。
对于二维ST表,记\(f[i][j][k][l]\),其中两个跨度放前面。
不然调试起来会很麻烦的。
代码
#include <cstdio>
#include <cctype>
#include <cmath>
#include <climits>
#include <algorithm>
using namespace std;
#define rep(i,a,b) for (int i=(a);i<=(b);i++)
const int N=1001;
const int U=10;
const int MAX=INT_MAX>>1;
const int MIN=INT_MIN>>1;
int n,m,siz;
int a[N][N];
int un,um; int unit;
int maxV[U][N][N],minV[U][N][N];
int res;
int rd(void) {
int x=0,f=1; char c=getchar();
for (;!isdigit(c);c=getchar()) if (c=='-') f=-1;
for (;isdigit(c);c=getchar()) x=x*10+c-'0';
return x*f;
}
int Query(int x,int y) {
int tx=(x-siz+1)+(1<<unit)-1;
int ty=(y-siz+1)+(1<<unit)-1;
int mx=MIN;
mx=max(mx,maxV[unit][x][y]);
mx=max(mx,maxV[unit][x][ty]);
mx=max(mx,maxV[unit][tx][y]);
mx=max(mx,maxV[unit][tx][ty]);
int mn=MAX;
mn=min(mn,minV[unit][x][y]);
mn=min(mn,minV[unit][x][ty]);
mn=min(mn,minV[unit][tx][y]);
mn=min(mn,minV[unit][tx][ty]);
return mx-mn;
}
int main(void) {
#ifndef ONLINE_JUDGE
freopen("bzoj1047.in","r",stdin);
freopen("bzoj1047.out","w",stdout);
#endif
n=rd(),m=rd(),siz=rd();
rep(i,1,n) rep(j,1,m)
a[i][j]=rd();
unit=(int)(log(siz)/log(2));
rep(i,0,unit) rep(j,1,n) rep(k,1,m) {
minV[i][j][k]=MAX;
maxV[i][j][k]=MIN;
}
rep(j,1,n) rep(k,1,m) {
minV[0][j][k]=a[j][k];
maxV[0][j][k]=a[j][k];
}
rep(i,1,unit) rep(j,1,n) rep(k,1,m) {
int tj=max(1,j-(1<<(i-1)));
int tk=max(1,k-(1<<(i-1)));
int *now=&(minV[i][j][k]);
*now=min(*now,minV[i-1][j][k]);
*now=min(*now,minV[i-1][j][tk]);
*now=min(*now,minV[i-1][tj][k]);
*now=min(*now,minV[i-1][tj][tk]);
now=&(maxV[i][j][k]);
*now=max(*now,maxV[i-1][j][k]);
*now=max(*now,maxV[i-1][j][tk]);
*now=max(*now,maxV[i-1][tj][k]);
*now=max(*now,maxV[i-1][tj][tk]);
}
res=MAX;
rep(i,siz,n) rep(j,siz,m) {
int t=Query(i,j);
res=min(res,t);
}
printf("%d\n",res);
return 0;
}
【bzoj1047】理想的正方形的更多相关文章
- bzoj1047理想的正方形
题目链接 纪念又双叒叕的一道暴力碾标算的题 我们考虑纯暴力 #include<iostream> #include<cstdio> #include<algorithm& ...
- bzoj1047 理想的正方形
Description 有一个a*b的整数组成的矩阵,现请你从中找出一个n*n的正方形区域,使得该区域所有数中的最大值和最小值的差最小. Input 第一行为3个整数,分别表示a,b,n的值第二行至第 ...
- 【BZOJ1047】[HAOI2007]理想的正方形(单调队列,动态规划)
[BZOJ1047][HAOI2007]理想的正方形(单调队列,动态规划) 题面 BZOJ 洛谷 题解 直接一个单调队列维护一下没给点和它前面的\(n\)个位置的最大值,再用一次单调队列维护连续\(n ...
- 【BZOJ1047】[HAOI2007]理想的正方形
[BZOJ1047][HAOI2007]理想的正方形 题面 bzoj 洛谷 题解 二维\(st\)表,代码是以前的 #include<iostream> #include<cstdi ...
- [bzoj1047][HAOI2007]理想的正方形_动态规划_单调队列
理想的正方形 bzoj-1047 HAOI-2007 题目大意:有一个a*b的整数组成的矩阵,现请你从中找出一个n*n的正方形区域,使得该区域所有数中的最大值和最小值的差最小. 注释:$2\le a, ...
- BZOJ1047: [HAOI2007]理想的正方形 [单调队列]
1047: [HAOI2007]理想的正方形 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 2857 Solved: 1560[Submit][St ...
- bzoj千题计划215:bzoj1047: [HAOI2007]理想的正方形
http://www.lydsy.com/JudgeOnline/problem.php?id=1047 先用单调队列求出每横着n个最大值 再在里面用单调队列求出每竖着n个的最大值 这样一个位置就代表 ...
- 【BZOJ1047】[HAOI2007]理想的正方形 (倍增ST表)
[HAOI2007]理想的正方形 题目描述 有一个\(a*b\)的整数组成的矩阵,现请你从中找出一个\(n*n\)的正方形区域,使得该区域所有数中的最大值和最小值的差最小. 输入输出格式 输入格式: ...
- HAOI2007 理想的正方形
1047: [HAOI2007]理想的正方形 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1402 Solved: 738[Submit][Sta ...
随机推荐
- ord函数-php
摘录自http://php.net/manual/zh/function.ord.php (PHP 4, PHP 5, PHP 7) ord — 返回字符的 ASCII 码值 说明 int ord ( ...
- PHP中的替代语法(冒号、endif、endwhile、endfor)
我们经常在wordpress一类博客程序的模板里面看到很多奇怪的PHP语法,比如: <?php if(empty($GET_['a'])): ?> <font color=" ...
- [转]SIP穿越NAT&FireWall解决方案
原文链接(也是转载)http://blog.csdn.net/yetyongjin/article/details/6881491.我修改了部分错字. SIP从私网到公网会遇到什么样的问题呢? 1 ...
- linux 中 ll 命令如何让查询结果按时间升序或降序排序?
-t选项的功能是使输出的结果将以时间降序排列.如果希望按时间的升序排列,可以使用管道符将返回的结果传入tac命令.用法示例:查询当前目录的文件并以降序排列: ll -t查询当前目录的文件并以升序排列: ...
- PostgresSql开放局域网访问
1) 确认已经退掉所有的MASF终端和MSF GUI,然后打开PostgresSQL的启动文件在文件POSTGRESQL_START参数后面添加-h 0.0.0.0,让PostgreSQL启动时绑定到 ...
- 生产者-消费者 用非阻塞队列、Object.wait()、Object.notify()实现
非阻塞队列,需要考虑到: 1.并发中的同步 2.线程间通信 public class Quene_Pro_Con { //定义队列大小 private static int size = 10; // ...
- jpg 批量压缩工具 v1.0
工作需要经常压缩大量图片,网上搜了一些 使用起来总觉得不方便.昨天自己用AIR 写了一个,功能简单,需要的朋友可以自己 下载使用win 版绿色版 http://pan.baidu.com/s/1k ...
- jQuery的.click,.bind,.unbind,.on,.off,.delegate,.undelegate
.click与.bind .click和.bind都是给每个元素绑定事件,对于只绑定一个click事件,.bind事件的简写就是.click那种方式. 这两种方式都会出现两个问题: 第一个问题,如果要 ...
- Java I/O NIO学习
给出一个学习的链接讲的很全.. http://ifeve.com/java-nio-all/ 上边的是中文翻译的这里是原地址:http://tutorials.jenkov.com/java-nio/ ...
- ASP.Net MVC4中封装CSS和js冗余代码(不让其大篇的显示在前台上)
(1)封装CSS和JS代码,使用调用的方式在前台进行调用.是开发看起来简洁和易于管理,可达到重用. 由于asp.netMVC4 框架 ,在封装js和CSS的时候,有如下规范: using Syst ...