题目大意:二维空间点修改,询问矩形区域最值。

题目分析:还是比较简单的。

代码如下:

# include<iostream>
# include<cstdio>
# include<cstring>
# include<algorithm>
using namespace std;
# define LL long long
# define mid (l+(r-l)/2) const int N=500;
const int INF=0x7fffffff; int maxn[N*4+5][N*4+5];
int minn[N*4+5][N*4+5]; bool leaf; void pushUpY(int id,int rt)
{
maxn[id][rt]=max(maxn[id][rt<<1],maxn[id][rt<<1|1]);
minn[id][rt]=min(minn[id][rt<<1],minn[id][rt<<1|1]);
} void buildY(int id,int rt,int l,int r)
{
if(l==r){
if(leaf){
int a;
scanf("%d",&a);
maxn[id][rt]=minn[id][rt]=a;
}else{
maxn[id][rt]=max(maxn[id<<1][rt],maxn[id<<1|1][rt]);
minn[id][rt]=min(minn[id<<1][rt],minn[id<<1|1][rt]);
}
}else{
buildY(id,rt<<1,l,mid);
buildY(id,rt<<1|1,mid+1,r);
pushUpY(id,rt);
}
} void buildX(int rt,int l,int r,int m)
{
if(l==r){
leaf=true;
buildY(rt,1,1,m);
}else{
buildX(rt<<1,l,mid,m);
buildX(rt<<1|1,mid+1,r,m);
leaf=false;
buildY(rt,1,1,m);
}
} void updateY(int id,int rt,int l,int r,int p,int v)
{
if(l==r){
if(leaf) maxn[id][rt]=minn[id][rt]=v;
else{
maxn[id][rt]=max(maxn[id<<1][rt],maxn[id<<1|1][rt]);
minn[id][rt]=min(minn[id<<1][rt],minn[id<<1|1][rt]);
}
}else{
if(p<=mid) updateY(id,rt<<1,l,mid,p,v);
else updateY(id,rt<<1|1,mid+1,r,p,v);
pushUpY(id,rt);
}
} void updateX(int rt,int l,int r,int p1,int p2,int v,int m)
{
if(l==r){
leaf=true;
updateY(rt,1,1,m,p2,v);
}else{
if(p1<=mid) updateX(rt<<1,l,mid,p1,p2,v,m);
else updateX(rt<<1|1,mid+1,r,p1,p2,v,m);
leaf=false;
updateY(rt,1,1,m,p2,v);
}
} void queryY(int id,int rt,int l,int r,int L,int R,int &mx,int &mn)
{
if(L<=l&&r<=R){
mx=max(mx,maxn[id][rt]);
mn=min(mn,minn[id][rt]);
}else{
if(L<=mid) queryY(id,rt<<1,l,mid,L,R,mx,mn);
if(R>mid) queryY(id,rt<<1|1,mid+1,r,L,R,mx,mn);
}
} void queryX(int rt,int l,int r,int L,int R,int L1,int R1,int &mx,int &mn,int m)
{
if(L<=l&&r<=R){
queryY(rt,1,1,m,L1,R1,mx,mn);
}else{
if(L<=mid) queryX(rt<<1,l,mid,L,R,L1,R1,mx,mn,m);
if(R>mid) queryX(rt<<1|1,mid+1,r,L,R,L1,R1,mx,mn,m);
}
} int main()
{
int n,q,a,b,c,d;
char op[2];
while(~scanf("%d",&n))
{
buildX(1,1,n,n);
scanf("%d",&q);
while(q--)
{
scanf("%s",op);
if(op[0]=='c'){
scanf("%d%d%d",&a,&b,&c);
updateX(1,1,n,a,b,c,n);
}else if(op[0]=='q'){
scanf("%d%d%d%d",&a,&b,&c,&d);
int ansA=-INF,ansB=INF;
queryX(1,1,n,a,c,b,d,ansA,ansB,n);
printf("%d %d\n",ansA,ansB);
}
}
}
return 0;
}

  

UVA-11297 Census(线段树套线段树)的更多相关文章

  1. UVA 11297 Census(二维线段树)

    Description This year, there have been many problems with population calculations, since in some cit ...

  2. bzoj 3196 Tyvj 1730 二逼平衡树(线段树套名次树)

    3196: Tyvj 1730 二逼平衡树 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1807  Solved: 772[Submit][Stat ...

  3. [BZOJ 1901] Dynamic Rankings 【树状数组套线段树 || 线段树套线段树】

    题目链接:BZOJ - 1901 题目分析 树状数组套线段树或线段树套线段树都可以解决这道题. 第一层是区间,第二层是权值. 空间复杂度和时间复杂度均为 O(n log^2 n). 线段树比树状数组麻 ...

  4. ZJOI 2017 树状数组(线段树套线段树)

    题意 http://uoj.ac/problem/291 思路 不难发现,九条カレン醬所写的树状数组,在查询区间 \([1,r]\) 的时候,其实在查询后缀 \([r,n]\) :在查询 \([l,r ...

  5. BZOJ4317Atm的树&BZOJ2051A Problem For Fun&BZOJ2117[2010国家集训队]Crash的旅游计划——二分答案+动态点分治(点分树套线段树/点分树+vector)

    题目描述 Atm有一段时间在虐qtree的题目,于是,他满脑子都是tree,tree,tree…… 于是,一天晚上他梦到自己被关在了一个有根树中,每条路径都有边权,一个神秘的声音告诉他,每个点到其他的 ...

  6. hdu-4819-线段树套线段树

    http://acm.hdu.edu.cn/showproblem.php?pid=4819 给出一个N*N的矩阵,每次询问一个m*m的子矩阵里的floor((maxv+minv)/2)并把中间的元素 ...

  7. dfs序+主席树 或者 树链剖分+主席树(没写) 或者 线段树套线段树 或者 线段树套splay 或者 线段树套树状数组 bzoj 4448

    4448: [Scoi2015]情报传递 Time Limit: 20 Sec  Memory Limit: 256 MBSubmit: 588  Solved: 308[Submit][Status ...

  8. 【vijos】1750 建房子(线段树套线段树+前缀和)

    https://vijos.org/p/1750 是不是我想复杂了.... 自己yy了个二维线段树,然后愉快的敲打. 但是wa了两法.......sad 原因是在处理第二维的更新出现了个小问题,sad ...

  9. [TJOI2017][bzoj4889] 不勤劳的图书管理员 [线段树套线段树]

    题面 传送门 思路 考虑两本书的位置交换对答案的贡献: (为了方便描述,用"左边那本"和"右边那本"称呼两本我们要交换的书,"中间那本"是我 ...

  10. 【bzoj4785】[Zjoi2017]树状数组 线段树套线段树

    题目描述 漆黑的晚上,九条可怜躺在床上辗转反侧.难以入眠的她想起了若干年前她的一次悲惨的OI 比赛经历.那是一道基础的树状数组题.给出一个长度为 n 的数组 A,初始值都为 0,接下来进行 m 次操作 ...

随机推荐

  1. 01-C语言概述

    本文目录 一.C语言简史 二.C语言的特点 三.C语言能做什么? 四.C语言的版本问题 五.C语言语法预览 回到顶部 一.C语言简史 C语言于1972年发明,首次使用是用于重写UINX操作系统(UNI ...

  2. C语言中常见的排序方法

    在C语言中,常见的排序方法有冒泡法,排序法,插入法等等.所谓的冒泡法,就是对一组数字进行从大到小或者从小到大的一种排序方法.主要就是相邻的数值相互交换.从第一个数值开始,如果这相邻的两个数值排序与我们 ...

  3. postgis数据库文件shapefile导入 dbf file (.dbf) can not be opened.shapefile import failed.

    Destination: public.train_polylineSource File: C:\Documents and Settings\Administrator\桌面\ffffff\tra ...

  4. jQuery学习笔记整理

    一.子元素选择器.:nth-child:匹配父元素下的第N个子或者奇偶元素.注意:序号是从1开始的,而eq是从0开始计数的!它匹配的是前方选择器选择到的元素的父元素下面的第几个元素.例如:ul li: ...

  5. M1卡介绍

    本文整理自网络. M1卡是指菲利浦下属子公司恩智浦出品的芯片缩写,全称为NXP Mifare1系列,常用的有S50及S70两种型号,目前都有国产芯片与其兼容,属于非接触式IC卡.最为重要的优点是可读可 ...

  6. 转:C++中的单例模式

    C++中的单例模式 单例模式也称为单件模式.单子模式,可能是使用最广泛的设计模式.其意图是保证一个类仅有一个实例,并提供一个访问它的全局访问点,该实例被所有程序模块共享.有很多地方需要这样的功能模块, ...

  7. CSS 3 动画2D

    动画分为两种,1,逐帧动画  组成动画的每一个画面就是一帧 2,关键帧动画,确定关键帧电脑会自动过度 动画中如果遇到不兼容的问题也是要加前缀 @-webkit-keyframes规则   @-webk ...

  8. swift混编oc碰到的问题

    在swift中混编苹果官方的Reachability OC文件. 因为swift工程的target是生成framework而非app,framework中调用oc与app中使用桥接文件还不一样,参考: ...

  9. 鼠标点击输入框文字消失 value placeholder 以及JQ实现效果 (仿京东的输入框效果)

    鼠标点击输入框文字消失 value实现方法  placeholder实现方法     以及JQ实现placeholder效果 <input type="text" value ...

  10. Bitmap旋转方法

    最近在做一个ORC图片解析的功能,要求解析出数字 但是发现他解析只能解析横着的图片,然后我拍照的时候拍的是竖直照片,当然你也可以去旋转照相机的屏幕 但是我这里为了方便选择的是竖直拍出来 然后,旋转下咯 ...