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 ...
随机推荐
- Spring MVC简单URL处理程序映射
以下示例显示如何使用Spring Web MVC框架来实现一个简单URL处理程序映射. SimpleUrlHandlerMapping类分别显式地将URL映射到相应的控制器上. 所下所示配置 - &l ...
- iOS学习笔记(六)——ViewController
ViewController是iOS应用程序中重要的部分,是应用程序数据和视图之间的重要桥梁,ViewController管理应用中的众多视图.iOS的SDK中提供很多原生ViewController ...
- SQL查临时表没有返回数据集
问题描述:在SQL中可以查询到数据,返回不到页面上. 解决办法: set nocount on create table #list [转] 每次我们在使用查询分析器调试SQL语句的时候,通常会看到一 ...
- jQuery之获取select选中的值
本来以为jQuery("#select1").val();是取得选中的值, 那么jQuery("#select1").text();就是取得的文本. 这是不正确 ...
- Storm 提交任务过程详解 (不对地方麻烦指正)
1.使用的是Storm中自带的一个测试jar包 提交下这任务到storm中去 storm jar /usr/local/app/storm/examples/storm-starter/storm-s ...
- RabbitMQ安装篇
一切不是自己实战,且跑不起来的程序都是在耍流氓! 先下载: http://www.erlang.org/downloads erlang 包
- coursera 《现代操作系统》 -- 第五周 同步机制(2)
分清紧急等待队列与条件等待队列(c 链) 条件等待队列:但是进入管程的这个进程可能由于对资源的操作的过程中发现条件不成熟, 那么它就不能够继续对资源进行相应的操作. 我们以生产者. 消费者为例. 如果 ...
- 通过天天模拟器加burpsuite抓取手机app流量
通过天天模拟器,代理抓取安卓app数据包.也可以抓取https. 1.下载天天模拟器,官方下载即可,下载安装. 2.启动天天模拟器,设置代理,点击上方wlan设置图标,打开wlan设置,如下: 3.鼠 ...
- 让VisualStudio Profiler捕捉执行的sql语句
启动Profiler之前设置一下Targets的属性就行,图中有说明.
- samba了解
1. samba是一个网络服务器,用于Linux和Windows之间共享文件 2,amba服务的启动.停止.重启 service smb start|stop|restart3. 掌握samba ...