模板到不行。。

连更新都没有。。

。存个模板。

理解留到小结的时候再写。

#include <algorithm>
#include <iostream>
#include <cstring>
#include <cstdlib>
#include <cstdio>
#include <queue>
#include <cmath>
#include <stack>
#include <map> #pragma comment(linker, "/STACK:1024000000");
#define EPS (1e-8)
#define LL long long
#define ULL unsigned long long
#define _LL __int64
#define _INF 0x3f3f3f3f
#define Mod 9999991
#define lowbit(x) (x&(-x)) using namespace std; struct N
{
int Min,Max;
}st[1200][1200]; int num[310][310]; void Init_Y(int s1,int s2,int l,int r,int t,int b)
{ if(t == b)
{
if(l == r)
{
st[s1][s2].Max = num[l][t];
st[s1][s2].Min = num[l][t];
}
else
{ st[s1][s2].Max = max(st[s1<<1][s2].Max,st[s1<<1|1][s2].Max);
st[s1][s2].Min = min(st[s1<<1][s2].Min,st[s1<<1|1][s2].Min);
}
return ;
} int mid = (t+b)>>1; Init_Y(s1,s2<<1,l,r,t,mid);
Init_Y(s1,s2<<1|1,l,r,mid+1,b); st[s1][s2].Max = max(st[s1][s2<<1].Max,st[s1][s2<<1|1].Max);
st[s1][s2].Min = min(st[s1][s2<<1].Min,st[s1][s2<<1|1].Min);
} void Init_X(int s1,int s2,int l,int r,int t,int b)
{
if(l != r)
{
int mid = (l+r)>>1; Init_X(s1<<1,s2,l,mid,t,b);
Init_X(s1<<1|1,s2,mid+1,r,t,b);
} Init_Y(s1,s2,l,r,t,b);
} N Query_Y(int s1,int s2,int L,int R,int T,int B,int l,int r,int t,int b)
{
if(T == t && B == b)
return st[s1][s2]; int mid = (T+B)>>1; if(b <= mid)
return Query_Y(s1,s2<<1,L,R,T,mid,l,r,t,b);
else if(mid < t)
return Query_Y(s1,s2<<1|1,L,R,mid+1,B,l,r,t,b);
N temp,t1,t2; t1 = Query_Y(s1,s2<<1,L,R,T,mid,l,r,t,mid);
t2 = Query_Y(s1,s2<<1|1,L,R,mid+1,B,l,r,mid+1,b); temp.Max = max(t1.Max,t2.Max);
temp.Min = min(t1.Min,t2.Min);
return temp;
} N Query_X(int s1,int s2,int L,int R,int T,int B,int l,int r,int t,int b)
{
if(L == l && R == r)
{
return Query_Y(s1,s2,L,R,T,B,l,r,t,b);
} int mid = (L+R)>>1; if(r <= mid)
return Query_X(s1<<1,s2,L,mid,T,B,l,r,t,b);
else if(mid < l)
return Query_X(s1<<1|1,s2,mid+1,R,T,B,l,r,t,b);
N temp,t1,t2;
t1 = Query_X(s1<<1,s2,L,mid,T,B,l,mid,t,b);
t2 = Query_X(s1<<1|1,s2,mid+1,R,T,B,mid+1,r,t,b);
temp.Max = max(t1.Max,t2.Max);
temp.Min = min(t1.Min,t2.Min);
return temp;
} int main()
{
int n,m,k,b,i,j,x,y; scanf("%d %d %d",&n,&b,&k); for(i = 1;i <= n; ++i)
{
for(j = 1;j <= n; ++j)
{
scanf("%d",&num[i][j]);
}
} Init_X(1,1,1,n,1,n); while(k--)
{
scanf("%d %d",&x,&y); N temp = Query_X(1,1,1,n,1,n,x,min(n,x+b-1),y,min(n,y+b-1)); printf("%d\n",temp.Max-temp.Min);
} return 0;
}

POJ 2019 Cornfields 二维线段树的初始化与最值查询的更多相关文章

  1. poj 2155 matrix 二维线段树 线段树套线段树

    题意 一个$n*n$矩阵,初始全为0,每次翻转一个子矩阵,然后单点查找 题解 任意一种能维护二维平面的数据结构都可以 我这里写的是二维线段树,因为四分树的写法复杂度可能会退化,因此考虑用树套树实现二维 ...

  2. POJ 2155 Matrix (二维线段树入门,成段更新,单点查询 / 二维树状数组,区间更新,单点查询)

    题意: 有一个n*n的矩阵,初始化全部为0.有2中操作: 1.给一个子矩阵,将这个子矩阵里面所有的0变成1,1变成0:2.询问某点的值 方法一:二维线段树 参考链接: http://blog.csdn ...

  3. POJ 2019 Cornfields [二维RMQ]

    题目传送门 Cornfields Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 7963   Accepted: 3822 ...

  4. poj 2155 matrix 二维线段树

    题目链接 区间翻转, 单点查询, 查询操作我真是不太明白...... #include <iostream> #include <vector> #include <cs ...

  5. POJ2029 二维线段树

    Get Many Persimmon Trees POJ - 2029 Seiji Hayashi had been a professor of the Nisshinkan Samurai Sch ...

  6. hdu 4819 二维线段树模板

    /* HDU 4819 Mosaic 题意:查询某个矩形内的最大最小值, 修改矩形内某点的值为该矩形(Mi+MA)/2; 二维线段树模板: 区间最值,单点更新. */ #include<bits ...

  7. poj 2155:Matrix(二维线段树,矩阵取反,好题)

    Matrix Time Limit: 3000MS   Memory Limit: 65536K Total Submissions: 17880   Accepted: 6709 Descripti ...

  8. poj 1195:Mobile phones(二维线段树,矩阵求和)

    Mobile phones Time Limit: 5000MS   Memory Limit: 65536K Total Submissions: 14391   Accepted: 6685 De ...

  9. POJ 2155 Matrix (二维线段树)

    Matrix Time Limit: 3000MS   Memory Limit: 65536K Total Submissions: 17226   Accepted: 6461 Descripti ...

随机推荐

  1. 74.资金管理-员工工资配置 extjs 页面

    1. <%@ page language="java" import="java.util.*" pageEncoding="UTF-8&quo ...

  2. Apache上php项目简单部署

    1.建一个简单的php项目 1)在目录C:\wamp\www中新建一个文件夹,命名为20151021 2)在文件夹20151021中新建一个index.php文件,内容为: <?php echo ...

  3. PCB Genesis加邮票孔(邮票孔增加方向判断--左右上下)实现算法

    之前没解决的问题,当时一下卡在用户界面选择邮票孔增加的方向(上下左右) 与邮票孔实际方位之前的逻辑与非判断上卡壳了,导致一下没进展下去. 回头看原来如此简单 ,将此点记录一下. 1.垂直线定义:80- ...

  4. Python 35 线程(2)线程特性、守护线程、线程互斥锁

    一:线程特性介绍 from threading import Thread import time n=100 def task(): global n n=0 if __name__ == '__m ...

  5. # 深入理解Redis(二)——内存管理的建议与技巧

    引语 随着使用Redis的深入,我们不可避免的需要深入了解优化Redis的内存,本章将重点讲解Redis的内存优化之道,同时推荐大家阅读memory-optimization一文. 想要高效的使用Re ...

  6. 9 在C#控制台程序(console)中让用户输入

    经过前面那些练习,我们已经熟悉录入一些简单的代码.这些代码可以进行一些简单的运算,在dos窗口打印出一些东西出来.我们现在要开始学习如何把数据从外部输入到我们的程序中. 其实大多数程序的工作是完成下面 ...

  7. javascript中执行环境和作用域(js高程)

    执行环境(execution context,为简单起见,有时也成为“环境”)是javascript中最为重要的一个概念.执行环境定义了变量或函数有权访问的其他数据,决定了它们各自的行为.每个执行环境 ...

  8. Django中关于MySQL的bug总结

    bug one: You are trying to add a non-nullable field 'height' to person without a default; we can't d ...

  9. DOM高级编程

    前言:W3C规定的三类DOM标准接口(换图)Core DOM(核心DOM),适用于各种结构化文档:XML DOM(Java OOP学过),专用于XML文档:HTML DOM,专用于HTML文档,下面了 ...

  10. SQL语言入门

    内容来源:唐成. PostgreSQL修炼之道[M]. 机械工业出版社, 2015. 此书购买链接:京东 亚马逊 SQL(Structured Query Language) 结构化查询语言 1. 语 ...