[HAOI2007] 理想的正方形

思路:

  正解多个单调队列;

  但是我用树套树水了过去;

来,上代码:

#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm> using namespace std; struct ReType {
int mi,ma;
}; struct TreeNodeType {
int l,r,lc,rc,ma,mi,mid;
};
struct TreeNodeType tree[(<<)*]; int tot=,a,b,n,root[],blo[],ans=0x7fffffff,X; inline ReType node(int k,int f)
{
ReType no;
no.mi=k,no.ma=f;
return no;
} inline void in(int &now)
{
char Cget=getchar();now=;
while(Cget>''||Cget<'') Cget=getchar();
while(Cget>=''&&Cget<='')
{
now=now*+Cget-'';
Cget=getchar();
}
} inline void tree_build(int &now,int l,int r)
{
now=++tot,tree[now].l=l,tree[now].r=r;
if(l==r)
{
in(tree[now].mi);
tree[now].ma=tree[now].mi;
return ;
}
tree[now].mid=l+r>>;
tree_build(tree[now].lc,l,tree[now].mid);
tree_build(tree[now].rc,tree[now].mid+,r);
tree[now].mi=min(tree[tree[now].lc].mi,tree[tree[now].rc].mi);
tree[now].ma=max(tree[tree[now].lc].ma,tree[tree[now].rc].ma);
} inline ReType tree_query(int now,int l,int r)
{
if(tree[now].l==l&&tree[now].r==r) return node(tree[now].mi,tree[now].ma);
if(r<=tree[now].mid) return tree_query(tree[now].lc,l,r);
else if(l>tree[now].mid) return tree_query(tree[now].rc,l,r);
else
{
ReType la=tree_query(tree[now].lc,l,tree[now].mid);
ReType ra=tree_query(tree[now].rc,tree[now].mid+,r);
return node(min(la.mi,ra.mi),max(la.ma,ra.ma));
}
} inline void tree_build_(int &now,int l,int r)
{
now=++tot,tree[now].l=l,tree[now].r=r;
if(l==r)
{
ReType an=tree_query(root[l],X-n+,X);
tree[now].mi=an.mi,tree[now].ma=an.ma;
return ;
}
tree[now].mid=l+r>>;
tree_build_(tree[now].lc,l,tree[now].mid);
tree_build_(tree[now].rc,tree[now].mid+,r);
tree[now].mi=min(tree[tree[now].lc].mi,tree[tree[now].rc].mi);
tree[now].ma=max(tree[tree[now].lc].ma,tree[tree[now].rc].ma);
} int main()
{
in(a),in(b),in(n);
for(int i=;i<=a;i++) tree_build(root[i],,b);
int pos=tot;
for(int i=n;i<=b;i++)
{
tot=pos,X=i,tree_build_(blo[i],,a);
for(int j=n;j<=a;j++)
{
ReType an=tree_query(blo[i],j-n+,j);
ans=min(ans,an.ma-an.mi);
}
}
cout<<ans;
return ;
}

AC日记——[HAOI2007]理想的正方形 P2216的更多相关文章

  1. 洛谷 P2216 [HAOI2007]理想的正方形

    P2216 [HAOI2007]理想的正方形 题目描述 有一个a*b的整数组成的矩阵,现请你从中找出一个n*n的正方形区域,使得该区域所有数中的最大值和最小值的差最小. 输入输出格式 输入格式: 第一 ...

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

    题目链接:P2216 [HAOI2007]理想的正方形 题目描述 有一个 \(a\times b\)的整数组成的矩阵,现请你从中找出一个 \(n\times n\)的正方形区域,使得该区域所有数中的最 ...

  3. P2216 [HAOI2007]理想的正方形 方法记录

    [HAOI2007]理想的正方形 题目描述 有一个 \(a \times b\) 的整数组成的矩阵,现请你从中找出一个 \(n \times n\) 的正方形区域,使得该区域所有数中的最大值和最小值的 ...

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

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

  5. BZOJ1047: [HAOI2007]理想的正方形 [单调队列]

    1047: [HAOI2007]理想的正方形 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 2857  Solved: 1560[Submit][St ...

  6. HAOI2007 理想的正方形

    1047: [HAOI2007]理想的正方形 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 1402  Solved: 738[Submit][Sta ...

  7. RAM——[HAOI2007]理想的正方形

    题目:[HAOI2007]理想的正方形 描述: [问题描述] 有一个a*b的整数组成的矩阵,现请你从中找出一个n*n的正方形区域,使得该区域所有数中的最大值和最小值的差最小. [输入]: 第一行为3个 ...

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

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

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

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

随机推荐

  1. A1031 Hello World for U (20)(20 分)

    A1031 Hello World for U (20)(20 分) Given any string of N (>=5) characters, you are asked to form ...

  2. 最短路径(最基础,经典的模板和思想):HDU-2544最短路

    题目: 最短路 Time Limit: 5000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Su ...

  3. LightOJ 1141 Number Transformation

    Number Transformation In this problem, you are given an integer number s. You can transform any inte ...

  4. js中基础数据类型

    变量声明 undefined //未定义只声明   var age; alert(name);function fc(a1,a2,a3) { //alert(a1); //alert(a2); //a ...

  5. Three Steps to Migrate Group Policy Between Active Directory Domains or Forests Using PowerShell

    Three Steps Ahead Have you ever wished that you had three legs? Imagine how much faster you could ru ...

  6. WebApi 跨域

    http://www.cnblogs.com/lori/p/3557111.html http://bbs.csdn.net/topics/391020576

  7. 46、android studio第一次使用时卡在gradle下载怎么解决?

    如果没法FQ或者FQ后网速慢,哥教你一个快速解决方案. 在根目录下的.gradle目录下,找到wrapper/dists目录,如果当前正在下载gradle.x.xx-all.zip,那么会发现grad ...

  8. Oracle 学习笔记(Windows 环境下安装 + PL/SQL)

    Oracle 安装.PL/SQL 配置使用  前言:因更换机械硬盘为 SSD 固态硬盘装了新 Windows 7 系统,需要重新搭建开发环境,把 Oracle 安装过程和 PL/SQL 配置使用做下笔 ...

  9. git基础之常用操作

    一.版本提交: (1)git add 文件名 (2)git commit -m "版本提交信息" 注:git分两个区:工作区+版本库 在电脑中看到的文件夹就是工作区 有一个隐藏的. ...

  10. 计算两个日期之间的天数差C++/java

    1--Java 分析:调用java中Calendar类 int days(Date date1,Date date2){ Calendar cal = new Calendar.getInstance ...