1047: [HAOI2007]理想的正方形 - BZOJ
Description
有一个a*b的整数组成的矩阵,现请你从中找出一个n*n的正方形区域,使得该区域所有数中的最大值和最小值的差最小。
Input
第一行为3个整数,分别表示a,b,n的值第二行至第a+1行每行为b个非负整数,表示矩阵中相应位置上的数。每行相邻两数之间用一空格分隔。
Output
仅一个整数,为a*b矩阵中所有“n*n正方形区域中的最大整数和最小整数的差值”的最小值。
Sample Input
5 4 2
1 2 5 6
0 17 16 0
16 17 2 1
2 10 2 1
1 2 2 2
Sample Output
1
问题规模
(1)矩阵中的所有数都不超过1,000,000,000
(2)20%的数据2<=a,b<=100,n<=a,n<=b,n<=10
(3)100%的数据2<=a,b<=1000,n<=a,n<=b,n<=100
看了题解,过了好几天又看这道题,感慨万分,好久不做RMQ果然什么都忘了
就是先做一遍右边的,把右边n格的最大值最小值存到最左边这一格
然后做一遍向下的,把下面n格的最值存到这一格,现在,每一个n*n的正方形的信息都存到左上角了,扫一遍就行了
const
maxn=;
var
a,b:array[..maxn,..maxn]of longint;
n,m,k:longint; procedure down(var x:longint;y:longint);
begin
if x>y then x:=y;
end; procedure up(var x,y:longint);
begin
if x<y then x:=y;
end; procedure main;
var
i,j,l,s,ans:longint;
begin
read(n,m,k);
for i:= to n do
for j:= to m do
begin
read(a[i,j]);
b[i,j]:=a[i,j];
end;
l:=;
while l<k do
begin
for i:= to n do
for j:= to m do
begin
s:=j+l;
down(s,m-l+);
down(s,j+k-l);
up(a[i,j],a[i,s]);
down(b[i,j],b[i,s]);
end;
l:=l<<;
end;
l:=;
while l<k do
begin
for i:= to n do
for j:= to m do
begin
s:=i+l;
down(s,n-l+);
down(s,i+k-l);
up(a[i,j],a[s,j]);
down(b[i,j],b[s,j]);
end;
l:=l<<;
end;
ans:=maxlongint;
for i:= to n-k+ do
for j:= to m-k+ do
down(ans,a[i,j]-b[i,j]);
write(ans);
end; begin
main;
end.
结果写完就被鄙视了,z55250825 ORZ,其实可以用单调队列
const
maxn=;
var
a,b:array[..maxn,..maxn]of longint;
n,m,k,ans:longint; function min(x,y:longint):longint;
begin
if x<y then exit(x);
exit(y);
end; procedure init;
var
i,j:longint;
begin
read(n,m,k);
for i:= to n do
for j:= to m do
begin
read(a[i,j]);
b[i,j]:=a[i,j];
end;
end; var
q:array[..maxn,..]of longint;
head,tail:longint; procedure work;
var
i,j:longint;
begin
for i:= to n do
begin
head:=;
tail:=;
for j:= to m do
begin
while (tail>=head) and (q[tail,]<=a[i,j]) do
dec(tail);
inc(tail);
q[tail,]:=j;
q[tail,]:=a[i,j];
while q[head,]<=j-k do
inc(head);
a[i,j]:=q[head,];
end;
end;
for j:= to m do
begin
head:=;
tail:=;
for i:= to n do
begin
while (tail>=head) and (q[tail,]<=a[i,j]) do
dec(tail);
inc(tail);
q[tail,]:=i;
q[tail,]:=a[i,j];
while q[head,]<=i-k do
inc(head);
a[i,j]:=q[head,];
end;
end;
for i:= to n do
begin
head:=;
tail:=;
for j:= to m do
begin
while (tail>=head) and (q[tail,]>=b[i,j]) do
dec(tail);
inc(tail);
q[tail,]:=j;
q[tail,]:=b[i,j];
while q[head,]<=j-k do
inc(head);
b[i,j]:=q[head,];
end;
end;
for j:= to m do
begin
head:=;
tail:=;
for i:= to n do
begin
while (tail>=head) and (q[tail,]>=b[i,j]) do
dec(tail);
inc(tail);
q[tail,]:=i;
q[tail,]:=b[i,j];
while q[head,]<=i-k do
inc(head);
b[i,j]:=q[head,];
end;
end;
ans:=maxlongint;
for i:=k to n do
for j:=k to m do
ans:=min(ans,a[i,j]-b[i,j]);
write(ans);
end; begin
init;
work;
end.
Wikioi上实在是过不了,然后写了一个C++的
#include<cstdio>
using namespace std; const int maxn=; int a[maxn][maxn],b[maxn][maxn],n,m,k,ans; int min(int x,int y)
{
return(x<y?x:y);
} void init()
{
int i,j;
scanf("%d%d%d",&n,&m,&k);
for(i=;i<=n;i++)
for(j=;j<=m;j++)
scanf("%d",&a[i][j]),b[i][j]=a[i][j];
} int q[maxn][],head,tail; void work()
{
int i,j;
for(i=;i<=n;i++)
{
head=;tail=;
for(j=;j<=m;j++)
{
while(tail>=head & q[tail][]<=a[i][j])--tail;
tail++;
q[tail][]=j;
q[tail][]=a[i][j];
while(q[head][]<=j-k)head++;
a[i][j]=q[head][];
}
}
for(j=;j<=m;j++)
{
head=;tail=;
for(i=;i<=n;i++)
{
while(tail>=head & q[tail][]<=a[i][j])tail--;
tail++;
q[tail][]=i;
q[tail][]=a[i][j];
while(q[head][]<=i-k)head++;
a[i][j]=q[head][];
}
}
for(i=;i<=n;i++)
{
head=;tail=;
for(j=;j<=m;j++)
{
while(tail>=head & q[tail][]>=b[i][j])tail--;
tail++;
q[tail][]=j;
q[tail][]=b[i][j];
while(q[head][]<=j-k)head++;
b[i][j]=q[head][];
}
}
for(j=;j<=m;j++)
{
head=;tail=;
for(i=;i<=n;i++)
{
while(tail>=head & q[tail][]>=b[i][j])tail--;
tail++;
q[tail][]=i;
q[tail][]=b[i][j];
while(q[head][]<=i-k)head++;
b[i][j]=q[head][];
}
}
ans=;
for(i=k;i<=n;i++)
for(j=k;j<=m;j++)
ans=min(ans,a[i][j]-b[i][j]);
printf("%d",ans);
} int main()
{
init();
work();
return ;
}
1047: [HAOI2007]理想的正方形 - BZOJ的更多相关文章
- bzoj 1047 : [HAOI2007]理想的正方形 单调队列dp
题目链接 1047: [HAOI2007]理想的正方形 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 2369 Solved: 1266[Submi ...
- BZOJ 1047: [HAOI2007]理想的正方形( 单调队列 )
单调队列..先对每一行扫一次维护以每个点(x, y)为结尾的长度为n的最大最小值.然后再对每一列扫一次, 在之前的基础上维护(x, y)为结尾的长度为n的最大最小值. 时间复杂度O(ab) (话说还是 ...
- [BZOJ 1047] [HAOI2007] 理想的正方形 【单调队列】
题目链接:BZOJ - 1047 题目分析 使用单调队列在 O(n^2) 的时间内求出每个 n * n 正方形的最大值,最小值.然后就可以直接统计答案了. 横向有 a 个单调队列(代码中是 Q[1] ...
- 【BZOJ】1047: [HAOI2007]理想的正方形(单调队列/~二维rmq+树状数组套树状数组)
http://www.lydsy.com/JudgeOnline/problem.php?id=1047 树状数组套树状数组真心没用QAQ....首先它不能修改..而不修改的可以用单调队列做掉,而且更 ...
- BZOJ 1047: [HAOI2007]理想的正方形
题目 单调队列是个很神奇的东西,我以前在博客写过(吧) 我很佩服rank里那些排前几的大神,700ms做了时限10s的题,简直不能忍.(但是我还是不会写 我大概一年半没写单调队列,也有可能根本没有写过 ...
- BZOJ 1047: [HAOI2007]理想的正方形 单调队列瞎搞
题意很简明吧? 枚举的矩形下边界和右端点即右下角,来确定矩形位置: 每一个纵列开一个单调队列,记录从 i-n+1 行到 i 行每列的最大值和最小值,矩形下边界向下推移的时候维护一下: 然后在记录的每一 ...
- bzoj 1047: [HAOI2007]理想的正方形【单调队列】
没有复杂结构甚至不长但是写起来就很想死的代码类型 原理非常简单,就是用先用单调队列处理出mn1[i][j]表示i行的j到j+k-1列的最小值,mx1[i][j]表示i行的j到j+k-1列的最大值 然后 ...
- 1047: [HAOI2007]理想的正方形
Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 4075 Solved: 2277[Submit][Status][Discuss] Descript ...
- bzoj千题计划215:bzoj1047: [HAOI2007]理想的正方形
http://www.lydsy.com/JudgeOnline/problem.php?id=1047 先用单调队列求出每横着n个最大值 再在里面用单调队列求出每竖着n个的最大值 这样一个位置就代表 ...
随机推荐
- Linux 命令 - lsof: 列出打开的文件
lsof 是一个列出当前系统打开文件的工具. 命令格式 lsof [ -?abChlnNOPRstUvVX ] [ -A A ] [ -c c ] [ +c c ] [ +|-d d ] [ + ...
- C#几个经常犯错误汇总
在我们平常编程中,时间久了有时候会形成一种习惯性的思维方式,形成固有的编程风格,但是有些地方是需要斟酌的,即使是一个很小的错误也可能会导致昂贵的代价,要学会善于总结,从错误中汲取教训,尽量不再犯同样错 ...
- iOS 在viewController中监听Home键触发以及重新进入界面的方法
第一步:创建2个NSNotificationCenter监听 [[NSNotificationCenter defaultCenter] addObserver:self selector:@sele ...
- linux/centos下安装nginx(rpm安装和源码安装)详细步骤
Centos下安装nginx rpm包 ...
- [求助]谁能给我讲解一下,iOS编程要如何实时显示采集到的图像???
rt,最近搞一个高清图传,本着自(bu)主(mai)创(da)新(jiang)的原则,打算利用手中的iPad当作辅助飞行屏幕,USB传输数据.再说某疆图传7999(还只支持自家云台录像拍照),哪是我这 ...
- Cocos2d-x中自定义粒子系统
除了使用Cocos2d-x的11种内置粒子系统外,我们还可以通过创建ParticleSystemQuad对象,并设置属性实现自定义粒子系统,通过这种方式完全可以实现我们说需要的各种效果的粒子系统.使用 ...
- 很牛逼的android真机调试,手机、平板、电视都可
1.首先通过路由器,搭建局域网 2.手机开wifi,记住ip地址,平板开wifi,记住ip地址,电视开wifi,记住ip 3.然后再eclipse里面“窗口-首选项-android-ddms里面设置使 ...
- javascript笔记——JavaScript经典实例
转载自百度文库 http://wenku.baidu.com/view/9a703522bcd126fff7050bfa.html 1. oncontextmenu="window.even ...
- 0-1背包问题与N皇后问题的纠结
昨日同学要我帮他看一道算法,如下: 是不是乍一看是“0-1背包”问题呀,我也这么想,于是就这么兴致勃勃的开始用这个想法去思考怎么算.但是算法也忘得差不多,回去赶紧补补,也趁着这次机会好好复习一下算法, ...
- 如何禁止KnockoutJs在VS2012的智能格式化
http://blogs.msdn.com/b/webdev/archive/2013/03/04/disabling-knockout-intellisense.aspx 我升级了一下VS2012, ...