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 ...
随机推荐
- php 按条件进行计算的方法
$isin = in_array($sheng,$s_sheng);//post过来的省的编码是否在s_sheng(自定义的数组)里,如果在,则加一,如果不在则不加一 if($isin){ //ech ...
- 第一百七十四节,jQuery,Ajax进阶
jQuery,Ajax进阶 学习要点: 1.加载请求 2.错误处理 3.请求全局事件 4.JSON 和 JSONP 5.jqXHR 对象 在 Ajax 课程中,我们了解了最基本的异步处理方式.本章,我 ...
- apache+svn No installed service name 'Apache2' 【转载】
版权声明:转载时请以超链接形式标明文章原始出处和作者信息及本声明http://zys0597.blogbus.com/logs/32763815.html 问题:第一次在winxp下 安装apac ...
- ios -WKWebView 高度 准确,留有空白的解决方案
#import "ViewController.h" #import <WebKit/WebKit.h> @interface ViewController ()< ...
- go http的三种实现---2
package main import ( "io" "log" "net/http" "os" ) func main ...
- JS原生追加子节点
var fragment = document.createDocumentFragment(); li = document.createElement('li'); li.className = ...
- 记录--前端 页面 jquery 被点击按钮修改样式 其他默认
jquery实现页面条件筛选 此功能类似淘宝的条件筛选,主要是页面样式的更改,问了大神也磨磨唧唧了很久才搞定0.0.... 先贴代码..... 代码知识有 border-radius 设置圆角边框 s ...
- 距离,margin padding ,width height 用法 ,记录
margin:0 auto 表示什么意思 margin后面如果只有两个参数的话,第一个表示top和bottom,第二个表示left和right 因为0 auto,表示上下边界为0,左右则根据宽度自适应 ...
- String、StringBuffer、StringBuiler区别
1.String与StringBuiler的相同点都是线程不安全的.StringBuffer是线程安全的. 2.String长度不可变,StringBuiler长度可变.当String 使用(+)连接 ...
- 监听浏览器使用不同版本js并且处理ie兼容getElementByClassName
if(window.addEventListener){ document.write('<script src="js/jquery-2.1.4.min.js">&l ...