UVA 11297 线段树套线段树(二维线段树)
题目大意:
就是在二维的空间内进行单个的修改,或者进行整块矩形区域的最大最小值查询
二维线段树树,要注意的是第一维上不是叶子形成的第二维线段树和叶子形成的第二维线段树要 不同的处理方式,非叶子形成的线段树总是在自身的叶子处不能直接更新数据,而是要以一维下他的左右孩子对应的位置数据进行更新。
#include <bits/stdc++.h>
using namespace std;
#define N 505
#define ls o<<1
#define rs o<<1|1
#define def_m int m=(l+r)>>1
const int INF = 0x7fffffff;
int n , q , mx[N*][N*] , mn[N*][N*] , ansmx,ansmn,a[N][N];
void update1D(int o , int l , int r , int y , int ox , int v,int flag)
{
if(l==r){
if(!flag)mx[ox][o] = mn[ox][o] = v;
else{mx[ox][o] = max(mx[ox<<][o],mx[ox<<|][o]) ; mn[ox][o] = min(mn[ox<<][o],mn[ox<<|][o]);}
return ;
}
def_m;
if(m>=y) update1D(ls,l,m,y,ox,v,flag);
else update1D(rs,m+,r,y,ox,v,flag);
mx[ox][o] = max(mx[ox][ls] , mx[ox][rs]);
mn[ox][o] = min(mn[ox][ls] , mn[ox][rs]);
// cout<<ox<<" "<<o<<" "<<l<<" "<<r<<" "<<y<<" "<<v<<endl;
}
void update2D(int o , int l , int r , int x , int y , int v)
{
// cout<<"v: "<<v<<endl;
if(l==r){
update1D(,,n,y,o,v,);
return ;
}
def_m;
if(m>=x) update2D(ls,l,m,x,y,v);
else update2D(rs,m+,r,x,y,v);
update1D(,,n,y,o,v,);
}
void query1D(int o , int l , int r , int s , int t , int ox)
{
if(l>=s&&r<=t){
ansmx=max(ansmx,mx[ox][o]);
// cout<<"in query: "<<ox<<" "<<o<<" "<<s<<" "<<t<<" "<<mx[ox][o]<<" "<<mn[ox][o]<<endl;
ansmn=min(ansmn,mn[ox][o]);
return ;
}
def_m;
if(m>=s) query1D(ls,l,m,s,t,ox);
if(m<t) query1D(rs,m+,r,s,t,ox);
}
void query2D(int o,int l,int r,int sx,int tx,int sy,int ty)
{
if(l>=sx&&r<=tx){
query1D(,,n,sy,ty,o);
return ;
}
def_m;
if(m>=sx) query2D(ls,l,m,sx,tx,sy,ty);
if(m<tx) query2D(rs,m+,r,sx,tx,sy,ty);
}
void build1D(int o , int l , int r , int ox , int x)
{
if(l==r){
if(x>=) mx[ox][o] = mn[ox][o] = a[x][l];
else mx[ox][o] = max(mx[ox<<][o] , mx[ox<<|][o]) , mn[ox][o] = min(mn[ox<<][o] , mn[ox<<|][o]);
return ;
}
def_m;
build1D(ls , l , m , ox , x);
build1D(rs , m+ , r , ox , x);
mx[ox][o] = max(mx[ox][ls] , mx[ox][rs]);
mn[ox][o] = min(mn[ox][ls] , mn[ox][rs]);
}
void build2D(int o , int l , int r , int ly , int ry)
{
if(l==r){
build1D(,,n,o,l);
return ;
}
def_m;
build2D(ls , l , m , ly , ry);
build2D(rs , m+ , r , ly , ry);
build1D( , , n , o , -);
}
int main()
{
// freopen("a.in" , "r" , stdin);
while(~scanf("%d" , &n)){
memset(mx , 0x80 , sizeof(mx));
memset(mn , 0x7f , sizeof(mn));
for(int i= ; i<=n ; i++)
for(int j= ; j<=n ; j++)scanf("%d" , &a[i][j]); build2D(,,n,,n); scanf("%d" , &q);
for(int i= ; i<q ; i++){
char op[];
scanf("%s" , op);
if(op[]=='q'){
int x1,y1,x2,y2;
scanf("%d%d%d%d" , &x1,&y1,&x2,&y2);
ansmx = -INF , ansmn=INF;
query2D(,,n,x1,x2,y1,y2);
printf("%d %d\n" , ansmx,ansmn);
}
else{
int x,y,v;
scanf("%d%d%d" , &x,&y,&v);
update2D(,,n,x,y,v);
}
}
}
return ;
}
UVA 11297 线段树套线段树(二维线段树)的更多相关文章
- 「ZJOI2017」树状数组(二维线段树)
「ZJOI2017」树状数组(二维线段树) 吉老师的题目真是难想... 代码中求的是 \(\sum_{i=l-1}^{r-1}a_i\),而实际求的是 \(\sum_{i=l}^{r}a_i\),所以 ...
- [BZOJ4785][ZJOI2017]树状数组(概率+二维线段树)
4785: [Zjoi2017]树状数组 Time Limit: 40 Sec Memory Limit: 512 MBSubmit: 297 Solved: 195[Submit][Status ...
- BZOJ4785 [Zjoi2017]树状数组 【二维线段树 + 标记永久化】
题目链接 BZOJ4785 题解 肝了一个下午QAQ没写过二维线段树还是很难受 首先题目中的树状数组实际维护的是后缀和,这一点凭分析或经验或手模观察可以得出 在\(\mod 2\)意义下,我们实际求出 ...
- P3688 [ZJOI2017] 树状数组 【二维线段树】
题目描述:这里有一个写挂的树状数组: 有两种共\(m\)个操作: 输入\(l,r\),在\([l,r]\)中随机选择一个整数\(x\)执行\(\text{Add}(x)\) 输入\(l,r\),询问执 ...
- 洛谷 P3688 - [ZJOI2017]树状数组(二维线段树+标记永久化)
题面传送门 首先学过树状数组的应该都知道,将树状数组方向写反等价于前缀和 \(\to\) 后缀和,因此题目中伪代码的区间求和实质上是 \(sum[l-1...n]-sum[r...n]=sum[l-1 ...
- hdu1823(二维线段树模板题)
hdu1823 题意 单点更新,求二维区间最值. 分析 二维线段树模板题. 二维线段树实际上就是树套树,即每个结点都要再建一颗线段树,维护对应的信息. 一般一维线段树是切割某一可变区间直到满足所要查询 ...
- 【BZOJ1513】[POI2006]Tet-Tetris 3D 二维线段树
[BZOJ1513][POI2006]Tet-Tetris 3D Description Task: Tetris 3D "Tetris" 游戏的作者决定做一个新的游戏, 一个三维 ...
- UVa 11297 Census (二维线段树)
题意:给定上一个二维矩阵,有两种操作 第一种是修改 c x y val 把(x, y) 改成 val 第二种是查询 q x1 y1 x2 y2 查询这个矩形内的最大值和最小值. 析:二维线段树裸板. ...
- UVA 11297 Census(二维线段树)
Description This year, there have been many problems with population calculations, since in some cit ...
随机推荐
- Query Designer:Hierarchy层级显示
声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...
- 让Xcode 8.x能够调试iOS 7.x真机
首先需要 Xcode 7.x.可以去 苹果开发者官网 下载. 打开Finder, 进入文件夹: Xcode .x.app/Contents/Developer/Platforms/iPhoneOS.p ...
- php : RBAC 基于角色的用户权限控制-表参考
--管理员表 CREATE TABLE `sw_manager` ( `mg_id` int(11) NOT NULL AUTO_INCREMENT, `mg_name` varchar(32) NO ...
- iOS - SQLite 数据库存储
1.SQLite 数据库 SQLite 是一种轻型的嵌入式数据库,安卓和 iOS 开发使用的都是 SQLite 数据库.它占用资源非常低,在嵌入式设备中,可能需要几百 K 的内存数据就够了.他的处理速 ...
- 【java项目小记--JManager】项目开始原因及github部署
--记于2016-8-11 毕业已三载,忽然想起大学时的毕业设计项目,想到曾在毕业答辩上说,会吸取老师点评并逐渐完善该项目.而今 老师点评已忘了个干净,项目也还是毕业时的样子,正好最近有些时间,打算兑 ...
- medoo–高效的轻量级PHP数据库操作类
网址:http://medoo.lvtao.net/ /*medoo.php*/ class medoo { protected $database_type = ‘mysql’; protected ...
- 对Android开发者有益的40条优化建议
下面是开始Android编程的好方法: 找一些与你想做事情类似的代码 调整它,尝试让它做你像做的事情 经历问题 使用StackOverflow解决问题 对每个你像添加的特征重复上述过程.这种方法能够激 ...
- zoj 1788 Quad Trees
zoj 1788 先输入初始化MAP ,然后要根据MAP 建立一个四分树,自下而上建立,先建立完整的一棵树,然后根据四个相邻的格 值相同则进行合并,(这又是递归的伟大),逐次向上递归 四分树建立完后, ...
- Android开发环境搭建(jdk+eclip+android sdk)
在开启Android 开发之旅之前,首先要把准备工作做好---搭建开发环境 一.环境搭建: 1.Java JDK 安装 2.Eclipse 安装 3.Android SDK 安装 4.ADT安装 5. ...
- MySQL使用技巧收集,持续更新中......
1.查询时按某一内容为中文的字段,以拼音字母排序: SELECT * FROM game ORDER BY CONVERT(name USING GBK);