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

  1. bzoj 1047 : [HAOI2007]理想的正方形 单调队列dp

    题目链接 1047: [HAOI2007]理想的正方形 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 2369  Solved: 1266[Submi ...

  2. BZOJ 1047: [HAOI2007]理想的正方形( 单调队列 )

    单调队列..先对每一行扫一次维护以每个点(x, y)为结尾的长度为n的最大最小值.然后再对每一列扫一次, 在之前的基础上维护(x, y)为结尾的长度为n的最大最小值. 时间复杂度O(ab) (话说还是 ...

  3. [BZOJ 1047] [HAOI2007] 理想的正方形 【单调队列】

    题目链接:BZOJ - 1047 题目分析 使用单调队列在 O(n^2) 的时间内求出每个 n * n 正方形的最大值,最小值.然后就可以直接统计答案了. 横向有 a 个单调队列(代码中是 Q[1] ...

  4. 【BZOJ】1047: [HAOI2007]理想的正方形(单调队列/~二维rmq+树状数组套树状数组)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1047 树状数组套树状数组真心没用QAQ....首先它不能修改..而不修改的可以用单调队列做掉,而且更 ...

  5. BZOJ 1047: [HAOI2007]理想的正方形

    题目 单调队列是个很神奇的东西,我以前在博客写过(吧) 我很佩服rank里那些排前几的大神,700ms做了时限10s的题,简直不能忍.(但是我还是不会写 我大概一年半没写单调队列,也有可能根本没有写过 ...

  6. BZOJ 1047: [HAOI2007]理想的正方形 单调队列瞎搞

    题意很简明吧? 枚举的矩形下边界和右端点即右下角,来确定矩形位置: 每一个纵列开一个单调队列,记录从 i-n+1 行到 i 行每列的最大值和最小值,矩形下边界向下推移的时候维护一下: 然后在记录的每一 ...

  7. bzoj 1047: [HAOI2007]理想的正方形【单调队列】

    没有复杂结构甚至不长但是写起来就很想死的代码类型 原理非常简单,就是用先用单调队列处理出mn1[i][j]表示i行的j到j+k-1列的最小值,mx1[i][j]表示i行的j到j+k-1列的最大值 然后 ...

  8. 1047: [HAOI2007]理想的正方形

    Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 4075  Solved: 2277[Submit][Status][Discuss] Descript ...

  9. bzoj千题计划215:bzoj1047: [HAOI2007]理想的正方形

    http://www.lydsy.com/JudgeOnline/problem.php?id=1047 先用单调队列求出每横着n个最大值 再在里面用单调队列求出每竖着n个的最大值 这样一个位置就代表 ...

随机推荐

  1. 【解决】应用程序无法正常启动(0xc000007b)。请单击“确定”关闭应用程序。

    换了SSD硬盘,装了Windows 7 SP1 x64的系统.用了一段时间,突然一天有些软件打不开了.弹出下面的提示 应用程序无法正常启动(0xc000007b).请单击“确定”关闭应用程序.第一时间 ...

  2. input 데이터의 자판입력모드의 한글/영문 자동전환, 영문고정 하는 방법 웹프로그래밍 팁

      input 태그의 style 속성의 ime-mode 변경으로 한글/영문의 자동전환이나 영문만 입력이 되도록 할 수 있다.     style="ime-mode:activ ...

  3. Agile.Net 组件式开发平台 - 内核管理组件

    敏捷开发体系   软件构件技术:所谓软件构件化,就是要让软件开发像机械制造工业一样,可以用各种标准和非标准的零件来进行组装.软件的构件化和集成技术的目标是:软件系统可以由不同厂商提供的,用不同语言开发 ...

  4. 给 Android 初学者的 Gradle 知识普及

    给 Android 初学者的 Gradle 知识普及:http://gold.xitu.io/entry/5778f8bd165abd0054b443b0/promote?utm_source=bai ...

  5. java 调用bash shell脚本阻塞的小问题的解决

    java  调用bash shell脚本阻塞的小问题的解决 背景 使用java实现的web端,web端相应用户的界面操作,使用java调用bash实现的shell脚本进行实际的操作,操作完成返回执行结 ...

  6. ASP.NET MVC 路由进阶(之二)--自定义路由约束

    3.自定义路由约束 什么叫自定义路由约束呢?假如路由格式为archive/{year}/{month}/{day},其中year,month,day是有约束条件的,必须是数字,而且有一定范围. 这时候 ...

  7. android xml的生成与解析

    Main java package com.itheima.xml; import android.app.Activity; import android.content.Context; impo ...

  8. spring aop配置及用例说明(3)

    欢迎转载交流:http://www.cnblogs.com/shizhongtao/p/3476336.html 1.这里说一下aop的@Around标签,它提供了在方法开始和结束,都能添加用户业务逻 ...

  9. Dribbble客户端应用源码

    简约大气的Dribbble客户端,帮你时刻紧跟潮流,版本描述,添加对Likes & Following的支持设计简约的Dribbble客户端,提供了全面的浏览功能,让你时刻紧跟潮流! A BE ...

  10. jQuery自己编写插件()

    引言: 在项目中不同页面经常要用到已经写好的交互,比如弹窗,比如下拉菜单,比如选项卡,比如删除... 此时如果每次都把代码copy一份无疑是一件比较麻烦并且无趣的事情,而且个人认为有些low了,我们可 ...