UVA11297 Census
题目
做法
二维线段树,单点修改,矩阵查询,树套树(\(x,y\)),维护最大值最小值废话
有一点要注意的是:\(x\)树传到\(y\)树里面修改的时候,如果\(x\)树中是叶子节点之间修改,否则在y树中还得拿\(x\)树中的左右儿子来修改
My complete code
#include<bits/stdc++.h>
using namespace std;
typedef int LL;
const LL inf=0x3f3f3f3f,maxn=2009;
LL n,xo,tmx,tmi,q;
LL Mx[maxn][maxn],Mi[maxn][maxn];
bool leaf;
void Modify1(LL now,LL l,LL r,LL c,LL val){
if(l==r){
if(leaf){
Mx[xo][now]=Mi[xo][now]=val; return;
}
Mx[xo][now]=max(Mx[xo<<1][now],Mx[xo<<1|1][now]),
Mi[xo][now]=min(Mi[xo<<1][now],Mi[xo<<1|1][now]);
return;
}
LL mid(l+r>>1);
if(c<=mid) Modify1(now<<1,l,mid,c,val);
else Modify1(now<<1|1,mid+1,r,c,val);
Mx[xo][now]=max(Mx[xo][now<<1],Mx[xo][now<<1|1]),
Mi[xo][now]=min(Mi[xo][now<<1],Mi[xo][now<<1|1]);
}
void Modify2(LL now,LL l,LL r,LL x,LL y,LL val){
if(l==r){
xo=now,leaf=true; Modify1(1,1,n,y,val);
return;
}
LL mid(l+r>>1);
if(x<=mid) Modify2(now<<1,l,mid,x,y,val);
else Modify2(now<<1|1,mid+1,r,x,y,val);
xo=now,leaf=false; Modify1(1,1,n,y,val);
}
void Query1(LL now,LL l,LL r,LL y1,LL y2){
if(y1<=l&&y2>=r){
tmx=max(tmx,Mx[xo][now]),tmi=min(tmi,Mi[xo][now]);
return;
}
LL mid(l+r>>1);
if(y1<=mid) Query1(now<<1,l,mid,y1,y2);
if(y2>mid) Query1(now<<1|1,mid+1,r,y1,y2);
}
void Query2(LL now,LL l,LL r,LL x1,LL x2,LL y1,LL y2){
if(x1<=l&&x2>=r){
xo=now,Query1(1,1,n,y1,y2);
return;
}
LL mid(l+r>>1);
if(x1<=mid) Query2(now<<1,l,mid,x1,x2,y1,y2);
if(x2>mid) Query2(now<<1|1,mid+1,r,x1,x2,y1,y2);
}
int main(){
cin>>n;
for(LL i=1;i<=n;++i)
for(LL j=1;j<=n;++j){
LL val;
cin>>val;
Modify2(1,1,n,i,j,val);
}
cin>>q;
while(q--){
char c;scanf(" %c ",&c);
if(c=='q'){
LL x1,y1,x2,y2; cin>>x1>>y1>>x2>>y2;
tmx=-inf,tmi=inf;
Query2(1,1,n,x1,x2,y1,y2);
cout<<tmx<<' '<<tmi<<endl;
}else{
LL x,y,val; cin>>x>>y>>val;
Modify2(1,1,n,x,y,val);
}
}return 0;
}
UVA11297 Census的更多相关文章
- UVA-11297 Census(线段树套线段树)
题目大意:二维空间点修改,询问矩形区域最值. 题目分析:还是比较简单的. 代码如下: # include<iostream> # include<cstdio> # inclu ...
- 图像变换之Census变换
图像的Census变换 Census变换属于非参数图像变换的一种,它能够较好地检测出图像中的局部结构特征,如边缘.角点特征等.传统Census变换的基本思想是:在图像区域定义一个矩形窗口,用这个矩形窗 ...
- [Machine Learning][The Analytics Edge][Predicting Earnings from Census Data]
census = read.csv("census.csv")library(caTools)set.seed(2000)spl = sample.split(census$ove ...
- UVA 11297 Census(二维线段树)
Description This year, there have been many problems with population calculations, since in some cit ...
- 立体匹配之Census Transform
1.立体匹配算法主要可分为两大类:基于局部约束和基于全局约束的立体匹配算法. (一)基于全局约束的立体匹配算法:在本质上属于优化算法,它是将立体匹配问题转化为寻找全局能量函数的最优化问题,其代表算法主 ...
- UVa 11297 Census (二维线段树)
题意:给定上一个二维矩阵,有两种操作 第一种是修改 c x y val 把(x, y) 改成 val 第二种是查询 q x1 y1 x2 y2 查询这个矩形内的最大值和最小值. 析:二维线段树裸板. ...
- UVA 11297 Census ——二维线段树
[题目分析] 二维线段树模板题目. 简直就是无比的暴力.时间复杂度为两个log. 标记的更新方式比较奇特,空间复杂度为N^2. 模板题目. [代码] #include <cstdio> # ...
- 【机器学习Machine Learning】资料大全
昨天总结了深度学习的资料,今天把机器学习的资料也总结一下(友情提示:有些网站需要"科学上网"^_^) 推荐几本好书: 1.Pattern Recognition and Machi ...
- 【数学】Jersey Politics
Jersey Politics Time Limit: 1000MS Memory ...
随机推荐
- go开启多进程——拆分多个进程同时处理(分而治之)
使用了goroutine实现了多线程,使用chan来控制多线程. runtime.GOMAXPROCS(3)来设置最大的原生线程. runtime.Gosched() 显式地让出CPU时间给其他gor ...
- Eclipse 重构菜单
Eclipse 重构菜单 使用Eclipse重构 在项目开发中我们经常需要修改类名,但如果其他类依赖该类时,我们就需要花很多时间去修改类名. 但 Eclipse 重构功能可以自动检测类的依赖关系并修改 ...
- python 设计模式之单例模式
单例模式就是防止每个请求到来,都需要在内存里创建一个实例,再通过该实例执行指定的方法. 如果并发量大的话,内存里就会存在非常多功能上一模一样的对象.存在这些对象肯定会消耗内存,对于这些功能相同的对象可 ...
- GoogleMap-------解决不能使用问题
前言:由于中国大部分Android手机中的Google服务都被阉割掉了,所以导致GoogleMap无法使用,可以用一下方法解决. 1.不能使用GoogleMap 2.若手机上装有安装市场之类的软件可搜 ...
- sourcenav安装
$ ./configure之后会出现 configure: error: ./configure failed for unixconfigure: error: ./configure failed ...
- PYTHON --WebAPP项目转载(廖雪峰) -- Day 1 -- 搭建开发环境
Day 1 - 搭建开发环境 搭建开发环境 首先,确认系统安装的Python版本是3.5.x: $ python3 --version Python 3.5.1 然后,用pip安装开发Web Ap ...
- Javadoc生成html帮助文档
注意事项: 右键项目 -> Export -> Java -> JavaDoc -> 选定Public表示录入所有的源文件,其他的可想而知 按步骤走下去最后Finish时 ...
- Consul文档收藏
英文:https://www.consul.io/intro/getting-started/install.html 中文:http://www.liangxiansen.cn/2017/04/06 ...
- Linux中的日志分析及管理
日志文件对于诊断和解决系统中的问题很有帮助,因为在Linux系统中运行的程序通常会把系统消息和错误消息写入相应的日志文件,这样系统一旦出现问题就会“有据可查”.此外,当主机遭受攻击时,日志文件还可以帮 ...
- CSS ,浮动,clear记录,和一些转载别处
DIV+CSS clear both清除产生浮动 我们知道有时使用了css float浮动会产生css浮动,这个时候就需要清理清除浮动,我们就用clear样式属性即可实现. clear 属性规定元素的 ...